

The #1 book in the industry — now revised & updated!



- The #1, easy-to-read, math-free introduction to semiconductor processing
- Perfect for training, teaching, & vo-tech programs
- Updated with new cleaning techniques, packing technologies, & fabrication methods

FOURTH EDITION

# Microchip Fabrication

A Practical Guide to  
SEMICONDUCTOR PROCESSING

PETER VAN ZANT

DEF085330

Library of Congress Cataloging-in-Publication Data

Van Zant, Peter.

Microchip fabrication : a practical guide to semiconductor processing / Peter Van Zant.—4th ed.

p. cm.

Includes bibliographical references and index.

ISBN 0-07-135636-3

1. Semiconductors—Design and construction. I. Title.

TK7871.85.V36 2000

621.3815'2—dc21

00-02317

McGraw-Hill



A Division of The McGraw-Hill Companies

Copyright © 2000, 1997, 1984 by The McGraw-Hill Companies, Inc. All rights reserved. Printed in the United States of America. Except as permitted under the United States Copyright Act of 1976, no part of this publication may be reproduced or distributed in any form or by any means, or stored in a data base or retrieval system, without the prior written permission of the publisher.

4 5 6 7 8 9 0 DOC/DOC 0 9 8 7 6 5 4 3 2

ISBN 0-07-135636-3

*The sponsoring editor for this book was Stephen Chapman and the production supervisor was Sherri Souffrance. It was set in Century Schoolbook by Pro-Image Corporation.*

*Printed and bound by R. R. Donnelley & Sons Company.*



This book is printed on recycled, acid-free paper containing a minimum of 50% recycled, de-inked fiber.

Information contained in this work has been obtained by The McGraw-Hill Companies, Inc. ("McGraw-Hill") from sources believed to be reliable. However, neither McGraw-Hill nor its authors guarantee the accuracy or completeness of any information published herein, and neither McGraw-Hill nor its authors shall be responsible for any errors, omissions, or damages arising out of use of this information. This work is published with the understanding that McGraw-Hill and its authors are supplying information but are not attempting to render engineering or other professional services. If such services are required, the assistance of an appropriate professional should be sought.

DEF085331

each process in turn requires a number of steps and substeps. A speculative process for a 64Gb CMOS device might require 180 major steps, 52 clean/strip, and up to 28 masks.<sup>1</sup> Yet all of the major steps are one of the four basic operations. Figure 4.11 lists the basic operations and the principle process options used for each. In this section, the building of a simple device, an MOS silicon gate transistor, is illustrated to explain a manufacturing sequence. The functions of the individual parts of this type of transistor and the operation of the transistor are explained in Chapter 14.

### Circuit design

Circuit design is the first step in creation of a microchip. A circuit designer starts with a block functional diagram of the circuit such as the logic diagram in Fig. 4.12. This diagram lays out the primary functions and operation required of the circuit. Next, the designer translates the functional diagram to a schematic diagram (Fig. 4.13). This diagram identifies the number and connection of the various circuit components. Each component is represented by a symbol. Accompanying the schematic diagram are the electrical parameters (voltage, current, resistance, etc.) required to make the circuit work.

The third step, circuit layout, is unique to semiconductor circuits. Circuit operation is dependent on a number of factors, including material resistivity, material physics, and the physical dimensions of the individual component "parts". Also the placement of the parts relative to each other is another factor. All these considerations dictate the physical layout and dimensions of the part/device/circuit. Layout starts with using sophisticated computer-aided design (CAD) systems to translate each circuit component into the physical shape and size. Through the CAD system, the circuit is built, exactly duplicating the final design. The result is a composite picture of the circuit surface showing all of the sublayer patterns. This drawing is called a *composite* (Fig. 4.14). The composite drawing is analogous to the blueprint of a multistory office building as viewed from the top and showing all of the floors. However, the composite is many times the dimensions of the final circuit.

Both buildings and semiconductor circuits are built one layer at a time. Therefore it is necessary to separate the composite drawing into the layout for each individual layer in the circuit. Figure 4.14 illustrates the composite and individual layer patterns for a simple silicon gate MOS transistor.

Each layer drawing is digitized (digitizing is the translation of the layer drawings to a digital data base) and plotted on a computerized X-Y plotting table.

## Overview of Wafer Fabrication 77

| Basic Operation | Process                         | Options                                                                                                                                                          |
|-----------------|---------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Layering        | Oxidation                       | Atmospheric<br>High Pressure<br>Rapid Thermal Oxidation (RTO)                                                                                                    |
|                 | Chemical Vapor Deposition (CVD) | Atmospheric Pressure<br>Low Pressure (LPCVD)<br>Plasma Enhanced (PECVD)<br>Vapor Phase Epitaxy (VPE)<br>Metaloranic CVD (MOCVD)                                  |
|                 | Molecular Beam Epitaxy (MBE)    |                                                                                                                                                                  |
|                 | Physical Vapor Deposition (PVD) | Vacuum Evaporation<br>Sputtering                                                                                                                                 |
| Patterning      | Resist                          | Positive<br>Negative<br>Contact<br>Proximity<br>Scanning Projection<br>Stepper                                                                                   |
|                 | Exposure Systems                |                                                                                                                                                                  |
|                 | Exposure Sources                | High Pressure Mercury<br>X-Rays<br>E-Beams                                                                                                                       |
|                 | Imaging Processes               | Single Layer Resist<br>Multilayer Resist<br>Antireflecting layers<br>Off-Axis Illumination<br>Annular Ring Illumination<br>Planarization<br>Contrast Enhancement |
|                 | Etch                            | Wet Chemistry-Liquid/vapor<br>Dry (Plasma)<br>Lift-Off<br>Ion Milling<br>Reactive Ion Etch (RIE)                                                                 |
| Doping          | Diffusion                       | Open Tube-Horizontal/Vertical<br>Closed Tube                                                                                                                     |
|                 | Ion Implantation                | Rapid Thermal Processing ( RTP)<br>Medium/High Current<br>Low/High Voltage (energy)                                                                              |
| Heating         | Thermal                         | Hot Plates<br>Convection<br>RTP                                                                                                                                  |
|                 | Radiation                       | Infrared (IR)                                                                                                                                                    |

Figure 4.11 Summary of wafer-fab operations/processes.

## 78 Chapter Four



Figure 4.12 Example functional logic design of a simple circuit.



Figure 4.13 Example circuit schematic diagram with component symbols.

**Reticle and masks**

The patterning process is used to create the required layer patterns and dimensions in and on the wafer surface. Getting the pattern from the digitized pattern to the wafer surface requires several steps. For the photo processes, there is an intermediate step called a reticle. A



Figure 4.14 Composite and layer drawings for 5-mask silicon gate transistor.

reticle is a “hard copy” of the individual drawing recreated in a thin layer of chrome deposited on a glass or quartz plate (Fig. 4.15a). The reticle may be used directly in the patterning process or may be used to produce a photomask. A photomask is also a glass plate with a thin chrome layer on the surface. After production, it is covered with many copies of the circuit pattern (Fig. 4.15b). It is used to pattern a whole wafer surface in one pattern transfer. (Reticle and mask-making processes are detailed in Chapter 11.)

The process from circuit design to wafer patterning is shown in Fig. 4.15. Reticles and masks are produced in a separate department or are purchased from outside vendors. They supply the fabrication area with a separate set of reticles or set of masks (*mask set*) for each circuit type.

### Example Fabrication Process

The manufacture of a circuit starts with a polished wafer. The cross section sequence in Fig. 4.16 shows the basic operations required to



Figure 4.15 (a) Chrome on glass reticle. (b) Photomask of same pattern.



Figure 4.16 Silicon gate MOS process steps.

form a simple MOS silicon-gate transistor structure. Following is an explanation of each operation in the fabrication process.

**Step 1: Layering Operation.** The building starts with an oxidation of the wafer surface to form a thin protective layer and to serve as a doping barrier. This silicon dioxide layer is called the *field oxide*.

**Step 2: Patterning Operation.** The patterning process leaves a hole in the field oxide that defines the location of the source, gate, and drain areas of the transistor.

**Step 3: Layering Operation.** Next, the wafer goes to an silicon dioxide oxidation operation. A thin oxide is grown on the exposed silicon. It will service as the gate oxide.

**Step 4: Layering Operation.** In step 4, another layering operation is used to deposit a layer of polycrystalline (poly) silicon. This layer will also become part of the gate structure.

**Step 5: Patterning Operation.** Two openings are patterned in the oxide/polysilicon layer to define the source and drain areas of the transistor.

**Step 6: Doping Operation.** A doping operation is used to create a n-type pocket in the source and drain areas.

**Step 7: Layering Operation.** Another oxidation/layering process is used to grow a layer of silicon dioxide over the source/drain areas.

**Step 8: Patterning Operation.** Holes, called contact holes, are patterned in the source, gate, and drain areas.

**Step 9: Layering Operation.** A thin layer of conducting metal, usually an aluminum alloy, is deposited over the entire wafer.

**Step 10: Patterning Operation.** After deposition, the wafer goes back to the patterning area where portions of the metallization layer are removed from the chip area and the scribe lines. The remaining portions connect all the parts of the surface components to each other in the exact pattern required by the circuit design.

**Step 11: Heat Treatment Operation.** Following the metal patterning step, the wafer goes through a heating process in a nitrogen gas atmosphere. The purpose of the step is to "alloy" the metal to the exposed source and drain regions and the gate region to ensure good electrical contact.

**Step 12: Layering Operation.** The final layer of this device is a protective layer known variously as a *scratch* or *passivation layer* (not shown in Fig. 4.5). Its purpose is to protect the components on the chip surface during the testing and packaging processes, and during use.

**Step 13: Patterning Operation.** The last step in the sequence is a patterning process that removes portions of the scratch protection

layer over the metallization terminal pads on the periphery of the chip. This step is known as the *pad mask* (not shown in Fig. 4.6).

The 12-step process illustrates how the four basic fabrication operations are used to build a particular transistor structure. The other components (diodes, resistors, and capacitors) required for the circuit are formed in other areas of the circuit as the transistors are being formed. For example, in this sequence resistor patterns are put on the wafer at the same time as the source/drain pattern for the transistor. The subsequent doping operation creates the source/drain *and* the resistors. Other transistor types, such as bipolar and silicon gate MOS, are formed by the same basic four operations, but using different materials and in different sequences.

### Chip Terminology

Figure 4.17 is a photomicrograph of an MOS medium-scale integration (MSI) integrated circuit. This level of integration was chosen so that the surface details could be seen. The components of higher-density circuits are so small that they cannot be distinguished on a photomicrograph of the entire chip. The chip features are:

1. A bipolar transistor
2. The circuit designation number
3. Bonding pads for connecting the chip into a package
4. A piece of contamination on a bonding pad
5. Metallization lines
6. Scribe (separation) line
7. Unconnected component
8. Mask alignment marks
9. Resistor

### Wafer Sort

Following the wafer-fabrication process comes a very important testing step, wafer sort. This test is the report card on the fabrication process. During the test, each chip is electrically tested for electrical performance and circuit functioning. Wafer sort is also known as *die sort* or *electrical sort*.

dry combinations as the mainstream photoresist removal process. Plasma stripping is used to remove hardened resist layers. A follow-on wet strip step is used to remove the residuals not removed by the plasma.

#### **Post-ion implant and plasma etch stripping**

Two problem areas are photresist removal after ion implant and after a plasma strip. Ion implant causes extreme polymerization of the resist and crusting of the top. Generally, the resist is removed or reduced with a dry process, followed by a wet process. Post-plasma etch resist layers are similarly difficult to remove. In addition, the etch process can leave residues, such as  $\text{AlCl}_3$  and/or  $\text{AlBr}_3$ , that react with water or air forming compounds that corrode the metal system.<sup>34</sup> Low temperature plasma can remove the offending compounds before they take on a corrosive chemistry. Another approach is to add halogens to the plasma atmosphere to minimize the formation of the insoluable metal oxides. This is another instance of setting process parameters to achieve efficient processing (resist removal) without inducing wafer surface damage or metal corrosion.

#### **Final Inspection**

The final step in the basic photomasking process is a visual inspection. It is essentially the same procedure as develop inspect, with the exception that the majority of the rejects are fatal (no rework is possible). The one exception is contaminated wafers that may be re-cleaned and reinspected. Final inspection certifies the quality of the outgoing wafers and serves as a check on the effectiveness of the develop inspection. Wafers that should have been identified and pulled from the batch at develop inspect are called *develop inspect escapes*.

The wafers receive a first surface inspection in incident white or ultraviolet light for stains and large particulate contamination. This inspection is followed by a microscopic or automatic inspection for defects and pattern distortions. Measurement of the critical dimensions for the particular mask level is also part of the final inspection. Of primary interest is the quality of the etched pattern with underetching and undercutting being two parameters of concern. The table in Fig. 9.29 is a list of typical causes of wafer rejection found in the final inspection.

#### **Mask Making**

In Chapter 5, the steps of circuit design were detailed. In this section, the process used to construct a photomask or reticle is examined. Orig-

process.  
A follow-  
ed by the

and after  
of the re-  
: reduced  
ch resist  
1 process  
th water  
low tem-  
they take  
ns to the  
ole metal  
ometers to  
ng wafer

| Possible Process Cause                           | Contamination | Misalign | Undercut | Incom-<br>plete Etch | Wrong Mask | Pin Holes | C.D.'s | Visual Reject |
|--------------------------------------------------|---------------|----------|----------|----------------------|------------|-----------|--------|---------------|
| Contaminated Etch                                | X             |          | X        | X                    |            |           |        |               |
| Contaminated Stripper                            | X             |          |          |                      |            |           |        |               |
| Contaminated H <sub>2</sub> O                    | X             |          |          |                      |            |           |        |               |
| Insufficient Rinse                               | X             |          | X        |                      |            |           |        |               |
| No Wet Agent                                     |               |          |          | X                    |            |           |        |               |
| Under Etch                                       |               |          |          | X                    |            |           | X      |               |
| Over Etch                                        |               |          | X        |                      |            |           |        | X             |
| Wrong Etch                                       |               |          | X        | X                    |            |           |        | X             |
| Hard Bake Too High                               |               |          | X        | X                    |            |           |        | X             |
| P <sub>2</sub> O <sub>5</sub> & SiO <sub>2</sub> |               |          | X        |                      |            |           |        | X             |
| B <sub>2</sub> O <sub>3</sub> & SiO <sub>2</sub> |               |          |          | X                    |            |           |        | X             |
| Low Hard Bake                                    |               |          | X        |                      |            |           |        |               |
| Develop Inspect Escapes                          |               | X        | X        | X                    | X          | X         | X      |               |

Figure 9.29 Final inspect rejects and process causes.

spection.  
h the ex-  
possible).  
aned and  
going wa-  
p inspec-  
from the

white or  
ion. This  
on for de-  
nensions  
ction. Of  
er stretching  
le in Fig.  
the final

s section,  
ed. Orig-

inally the masks were made from emulsion-coated glass plates. The emulsions are similar to those found on camera film. These masks were vulnerable to scratches, deteriorated during use, and were not capable of resolving images in the sub 3 micron range. Masks for most modern work use a chrome on glass technology. This mask-making technology is almost identical to the basic wafer-patterning operation (Fig. 9.30). In fact the goal is the same, the creation of a pattern in the thin chrome layer on the glass reticle surface. The preferred materials for mask/reticles are borosilicate glass or quartz, which have good dimensional stability and transmission properties for the wavelengths of the exposing sources. Chrome layers are in the 1000-Å range and deposited on the glass by sputtering (see Chapter 12). Advanced mask/reticles use layers of chromium, chromium oxide, and chromium nitride.<sup>35</sup>

Mask/reticle making follows a number of different paths depending on the starting exposure method (pattern generation, laser, e-beam) and the end result (reticle or mask) (Fig. 9.31). Flow A shows the process for making a reticle using a pattern generator, which is an older technology. A pattern generator consists of a light source and a series of motor-driven shutters. The chrome-covered mask/reticle, with a layer of photoresist is moved under the light source as the shutters are moved and opened to allow precisely shaped patterns of



Figure 9.30 Major steps in mask/reticle plate processing.

light to shine onto the resist creating the desired pattern. The reticle pattern is transferred to the resist-covered mask blank by a step-and-repeat process to create a master plate. The master plate is used to create multiple working mask plates in a contact printer. This tool brings the master into contact with a resist-covered mask blank and has a UV light source for transferring the image. After each of the exposure steps (pattern generation, laser, e-beam, master plate expose, and contact print), the reticle/mask is processed through development, inspection, etch, strip, and inspection steps that transfer the pattern permanently into the chrome layer. Inspections are very critical since any undetected mistake or defect has the potential of creating thousands of scrap wafers. Reticles for this use are generally 5 to 20 times the final image size on the mask.<sup>36</sup>

Advanced products with very small geometries and tight alignment budgets require high quality reticle and/or masks. The reticles and masks for these processes are made with lasers or e-beam direct write exposure (Flow A & B). Laser exposure uses a wavelength of 364 nm making it an I-line system. It allows using standard optical resists and is faster than e-beam. Direct write laser sources are turned on and off with an acousto-optical modulator (AOM).<sup>37</sup> In all cases, the reticle or mask is processed to etch the pattern in the chrome.



Figure 9.31 Mask/reticle-making processing flows.

Other mask/reticle process flows may be employed. The reticle in Flow A may be laser/e-beam generated or the master plate may be laser/e-beam generated.

VLSI and ULSI-level circuits require virtually defect-free and dimensionally perfect masks and reticles. Critical dimension (CD) budgets from all sources are 10% or better, leaving the reticles with a 4% error margin.<sup>38</sup> There are procedures to eliminate unwanted chrome spots and pattern protrusions with laser “zapping” techniques. Focused ion beams (FIB) is the preferred repair technology for small image masks and reticles. Clear or missing pattern parts are “patched” with a carbon deposit. Opaque or unwanted chrome areas are removed by sputtering from the beam.

### Summary

For VLSI and ULSI work, the resolution and registration requirements are very stringent. In 1977, the minimum feature size was 3

ie reticle  
step-and-  
is used to  
This tool  
ank and  
h of the  
plate ex-  
gh devel-  
asfer the  
very criti-  
al of cre-  
nally 5

ignment  
cles and  
ect write  
364 nm  
l resists  
urned on  
ases, the  
e.

$\mu\text{m}$ . By the mid 1980s, it had passed the 1 micron barrier. By the 1990s 0.5 micron sizes were common with  $0.35\text{-}\mu\text{m}$  technology planned for production circuits. Circuit design projections call for minimum feature sizes less than  $0.1\text{ }\mu\text{m}$ .<sup>39</sup>

Chip manufacturers calculate several *budgets* for each circuit product. A *CD* (critical dimension) *budget* calculates the allowable variation in the image dimensions on the wafer surface. For products with submicron minimum feature sizes, the *CD* tolerances are 10 to 15%.<sup>40</sup> Also of concern is the critical defect size relative to the minimum feature size. These two parameters are brought together in an *error budget* calculated for the product. Error budgets for various DRAM products are illustrated in Fig. 9.31. An *overlay budget* is the allowable accumulated alignment error for the entire mask set. A rule of thumb is that circuits with micron or submicron feature sizes must meet registration tolerances of one-third the minimum feature. For a  $0.35\text{-}\mu\text{m}$  product, the allowable overlay budget is about  $0.1\text{ }\mu\text{m}$ .<sup>41</sup>

### Key Concepts and Terms

|                            |                            |
|----------------------------|----------------------------|
| Alignment error budget     | Negative resist developers |
| Develop inspect and rework | Plasma descum              |
| Dry etch methods           | Positive resist developers |
| Dry stripping              | Puddle develop             |
| Etch process               | Resist development         |
| Final inspect              | Resist stripping           |
| Hard bake methods          | Spray develop              |
| Hard bake process          | Wet etch methods           |
| Immersion develop          | Wet strip chemicals        |
| Mask making                |                            |

### Review Questions

1. Name the major methods of resist development.
2. What are the chemicals used to develop negative and positive resist?
3. What is the purpose of the hard bake step?
4. Name three methods used for hard bake.
5. What problems arise if the hard bake temperature is too low? Too high?



# CAD Tool Integration For ASIC Design: An End-Users Perspective

Pankaj Kukkal, Masato Imaizumi\*,  
and Hideaki Kobayashi  
Electrical and Computer Engineering  
University of South Carolina  
Columbia, South Carolina

## Abstract

The increasing complexity of VLSI design and the demand for quick-turnaround ASICs has forced the designer to choose the best CAD tools available from different vendors and integrate them into a customized and comprehensive CAD system. Vendors have developed comprehensive but open systems, called CAD frameworks, to ease the process of CAD tool integration.

This paper describes the ASIC development process and issues relating to CAD tool integration. In addition, state-of-the-art CAD frameworks and their impact on ASIC designers are described.

## I. Introduction

Application specific integrated circuits (ASIC) technology has brought a great revolution in VLSI system design. Before the advent of ASICs, systems were designed using a set of standard IC chips, whereas whole systems can now be designed into a single chip. ASICs are usually low volume products. Shorter design cycles are required to make the product cost competitive. Short design cycles imply increased dependence on CAD tools. To meet the demand of quick-turnaround ASICs, CAD tools have been developed to automate almost all the phases of ASIC design.

However, with increasing design complexities and design data, the flow of the design data through the CAD tools at various phases of the design cycle has become a cumbersome task for the ASIC designer. To relieve the designer of this burden, integrated CAD systems were developed. Initially, these systems were only a collection of tightly integrated tools. Adding and deleting tools was difficult, and usually these CAD systems were incompatible with each other. Such a closed environment is slow to evolve and the designer is restricted to a limited set of tools. Thus the concept of open design environments called CAD frameworks evolved. This concept is receiving wide attention in the area of computer aided design. A group of tool users, vendors, and system integrators, the CAD framework initiative (CFI), has set out to establish guidelines for a standard CAD framework. Thus we can look forward to a framework that encompasses all areas related to VLSI design such as specification capture, logic design, verification and testing.

## II. Application Specific ICs

### Definition

ASICs are ICs designed for a specific application, in contrast to standard ICs that are used in different applications. ASICs are a class of ICs that are in between the domain of software programmable generic components, for example microprocessors, and hardware programmable components, for

\* M. Imaizumi is a Visiting Researcher to the Department of Electrical and Computer Engineering on leave from LSI Project, NKK Corporation, 2-6-3 Hitotsubashi, Chiyodaku, Tokyo 101, Japan.

example PLDs [KEUT, '89]. They can also be called custom-built ICs.

### Characteristics

State-of-the-art electronics products such as digital signal processors, voice synthesizers, automatic focusing systems in cameras, etc. use ASICs. For prototypes, the circuits are designed by using a set of standard IC products but later for commercial products they are redesigned as an ASIC chip. System development cost is reduced by incorporating different components of the system, for example system controllers, RAMs, ROMs, PLDs, etc., into an ASIC. This technology also reduces the size of printed circuit boards thus reducing production cost. However, once systems are integrated into a chip, correcting even a small error, requires re-designing and re-fabricating the entire chip. Also, reduced node accessibility creates testing problems. Testing currently occupies 30-50 percent of the production cost of ASIC chips [LEUN, '88].

The ASIC designer uses a lot of CAD tools to reduce ASIC design time but has to sacrifice flexibility with regards to minimizing area and maximizing speed. A survey of ASICs designed for use by AT&T summarizes some common characteristics of ASICs [KEUT, '89].

- *Control dominated* - Design of the control circuitry in the ASIC takes up a majority of circuit area and design time.
- *Arithmetic Structures* - Few large arithmetic circuits are present in an ASIC.
- *Speed/area* - Even though high speed and component density are achievable, most ASICs use under 10,000 logic (non-memory) transistors and operate at no more than 10 MHz.
- *Regularity of structure* - ASIC designers use as many regular structures for e.g. library cells, gate arrays, etc. as possible.
- *Analog interfaces* - Many asynchronous and analog interfaces are used.

## III. ASIC Design Styles and Methodology

### Design Styles

Designers can employ various design styles to design ASICs. Some of the design styles and trade-offs involved are described below.

*Gate arrays* - In this style gates are pre-arranged, with space for channel routing. These gates are then interconnected by customizing metal layers. All levels of masks, except the metal interconnections, are predefined so that the wafer can largely be pre-fabricated. This prefabrication of wafers, called masterslices, is the main reason for fast turn-around time of prototype gate arrays. Due to its limited design freedom, the chip size of the gate array is typically two or three times that of a handcrafted design [LEUN, '88].

*Sea of gates* - This style is similar to gate arrays but has no

KBSC000031

predefined routing channels. So, sea-of-gates is also called "channel less gate array" and is more effective in area reduction than gate arrays.

**Standard cell** - Standard cells, for example, basic cells like inverters, NAND gates, Flip-Flops, etc., are pre-designed and are a part of a cell library. Placement and routing can both be customized. Usually all cells are of fixed height and a channel router is used to accomplish the interconnections. Pre-fabricated wafers are not used in this style.

**PLDs** - Programmable logic devices include PLAs, which are generated by automatic PLA generators and are usually used to implement system controllers.

**Custom cells** - Custom cells are designed to implement special functions that are not available in the library. If these custom cells are designed according to standard cell height specifications, then they can be added to the cell library and used with standard cells.

**Silicon compilers** - Once silicon compilers come of age the designer need only provide behavioral descriptions of the circuit and the corresponding hardware will be synthesized on silicon automatically. Presently, silicon compilers are used for generating megacells [LEUN,'88].

Usually, an ASIC is a mixture of modules designed using different design styles. For example, IBM has developed a design system that allows complete mixing of standard cell and gate array functions [LEUN,'88]. Thus we are moving towards an era where changing from one design style to another will be easy. This implies that designers will no longer be required to make tradeoffs between the various design styles. An integrated design environment will provide the designer with a complete solution to intermixing various styles.

#### Design methodology

Various aspects of VLSI design can be partitioned hierarchically into levels of abstraction. Design tools are used to implement the design at these levels. *Table 1* describes an example of hierarchical levels, levels of abstractions, and CAD tools required to implement the design at these levels. A methodology is a sequence of design steps that links the design process from specification capture to mask layout. There are basically two types of hierarchical design methodologies: top-down (see *Figure 1*) and bottom-up. In top-down design methodology, a design is first described in general terms at some high level of design abstraction. Designers then recursively decompose and elaborate the design. In the bottom-up method the most detailed parts are designed first and then global layout is determined by combining these parts. Today, most designers employ the top-down design approach.

#### IV. ASIC Development Process

The ASIC development process is divided into four major areas. The design process being an important part of the overall ASIC development process, is presented here in greater detail.

**Specification Capture** - During specification capture, the objective or goal of designing the chip is decided. The performance characteristics and functionality of the chip are set forth. All constraints regarding the environment (i.e. all external factors affecting the chip in any possible way) are precisely defined [CAVI,'90].

**Design Synthesis and Verification** - This stage of ASIC development encompasses all the design phases from system design to the final mask layout. It can be viewed as a process of successive transformations from one hierarchical level to another.

Different phases of design synthesis and verification for a top-down design approach are listed as follows:



Figure 1. The top-down design process.

- a. System is designed according to the specifications.
- b. Decisions on fabrication process, for example the technology to be used, are made.
- c. Functional partitioning of the system into modules is done.
- d. Specifications for each module are set at some level of abstraction as shown in *Table 1*.
- e. Through a series of mapping and translation steps the design is taken down through the hierarchical levels, as shown in *Table 1*, to the logic design level.
- f. Logic is verified.
- g. The design is mapped down to the layout design level.
- h. Inverse mapping (mapping from a lower level to a higher level) is done and the layout is verified for consistency with the logic design.
- i. Logic and timing verification is performed at the layout level.
- j. Mask layout for the chip is obtained in a standard format, for example CIF, and sent to the fabrication house.

Table 1. Hierarchical and abstraction levels.

| Hierarchy Levels  | Abstraction Levels                               | CAD Tools                                                                           |
|-------------------|--------------------------------------------------|-------------------------------------------------------------------------------------|
| System            | Timing behavior, pin assignments                 | Flowcharts, Block-diagrams, High level languages                                    |
| Architecture      | Organization of functional blocks                | HDLs, Floorplanning, Block diagrams                                                 |
| Register transfer | Developing specifications for functional modules | Synthesis, Simulation, Verification, Test analysis                                  |
| Logic             | Boolean functions, Gate level circuits           | Schematic entry, Simulation, Verification.                                          |
| Transistor        | Electrical properties of transistor circuits     | SPICE, Timing verification                                                          |
| Layout            | Geometric constraints                            | Layout editor, DRC and ERC programs, Netlist extractor, Placement and Routing tools |



Figure 2. ASIC design flow.

Figure 2 depicts a typical ASIC design process. It can be seen from the figure that backtracking and iteration are required throughout the design process.

**Fabrication** - VLSI chips are fabricated by a complex series of about 100 or more steps. These steps create transistor parts, circuit elements, insulating layers, and metallized paths on silicon. Some major steps are thermal oxidation, lithography, etching, ion implantation, thermal redistribution, insulation, and metallization [STRO,'88].

**Testing and Verification** - Design verification techniques are used to qualify the ASIC to be marketed/supplied. At this stage the fabricated chip is tested for the specified external environment under accelerated stress conditions. Other tests to detect manufacturing defects are also carried out. Undetected errors in an ASIC can be very costly due to additional manufacturing costs and delay to market.

#### V. CAD Tools for ASIC Design

It is apparent from Table 1 and Figure 2 that a number of CAD tools are required to accomplish ASIC design tasks. These tools are classified as follows. (Examples for each class are taken from the UC Berkeley VLSI tool suite [SCOT,'85].)

**Mapping Tools** - These are used for schematic capture, interactive layout, graphical entry, text entry, placement and routing. For example, MAGIC layout editor is used for interactive layout, PEG is a text entry tool used for obtaining Boolean equations corresponding to a text that describes state diagrams.

**Translation Tools** - These are used for transforming files from one format to another to ensure compatibility between tools. For example, EXT2SIM is a tool for transforming the output of MAGIC layout editor to a format that is readable by simulator tools like ESIM and CRYSTAL.

**Validation Tools** - These tools check for violations of design rules. For example, the built-in Design Rule Checker (DRC) in the MAGIC layout editor concurrently checks for design rule

(design rules depend on technology and fabrication process) violations while the designer is laying out the design. There are CAD tools that perform Electrical Rule Checking (ERC) and check for connectivity of all the elements of the design.

**Verification Tools** - Logic and timing simulation on designs are performed by these tools. For example, ESIM is used for logic verification, CRYSTAL and SPICE are used for Timing verification.

**Optimization Tools** - Optimization tools are used to optimize area and speed. Area can be optimized by either layout compaction or reduction in the logic required to implement the design. For example, PLEASURE is used for PLA folding, and ESPRESSO is used for minimizing Boolean equations. Speed optimization depends largely on the designers expertise.

Along with the CAD tools the ASIC designer requires cell libraries. Cell libraries are a collection of primitive components, which can be individual transistors, logic gates or entire subsystems. These libraries may be traditional standard cells, gate array building blocks, parameterized cells such as those synthesized by silicon compilers, or sophisticated cells generated by module generators [NEWT,'86].

#### Invoking and Executing CAD tools

Some basic terms required for this discussion are defined [FIDU,'90] as:

- **Process** is a specific combination of tools and/or other processes that perform a design function.
- **Task** is an abstraction of a design function, e.g., simulation. Tasks are performed by invoking specific processes.

Whatever design methodology/style is employed, an ASIC designer needs to perform a sequence of tasks by using a set of CAD tools and cell libraries. A designer needs to invoke and execute each CAD tool required for ASIC design. This implies that he needs to select an appropriate tool for the given task and then execute that tool so that it accomplishes exactly what needs to be done. To select a tool, the designer needs to know the various available tools for the given task and then chose the best. This can only be done if the designer knows the exact functionality of all the CAD tools. The designer also needs information on the versions of CAD tools available. Thus many decisions are required even before invoking a tool. To execute the selected tool the designer needs to know the exact syntax for tool invocation, and semantics of the tool.

The designer also has to manage all design data files related to the tools. As most tools are incompatible with regards to input and/or output file formats the designer needs to translate these files [BUSH,'89]. For example, to run a simulation on a layout, geometrical information needs to be extracted from the layout and then converted to a file format that can be input to a simulator. The whole design, from behavioral description to mask layout, needs to be steered by the designer using the CAD tools. The designer can be relieved of these painstaking tasks if the following information about all the tools is embedded in the system:

- **Data requirements**; type, access modes, format, etc.
- **Argument definitions**; format, required/optional, purpose, etc.
- **Tool commands**; syntax, arguments, purpose, effect, etc.
- **Resource requirements**; regarding CPU time, memory, etc.
- **Description of tool functions**.

In [DANI,'89] an object-oriented approach to build models of CAD tools has been proposed. By binding a CAD tool to its representative model, they create a CAD tool knowledge object

(CTKO). The CTKO represents the abilities of the tool to the designer, manages the low level programming details associated with the original tool, and provides a control mechanism between the tool and the designer.

#### CAD tool integration

CAD tools in the past decade have automated almost all the phases of the design process. The need of this decade is to integrate CAD tools into a design automation system. ASIC designers require an environment for integrating heterogeneous CAD tools while providing an open and distributed control mechanism. The need for CAD tool integration can be discussed with respect to four sub-topics as follows:

**Design data management** - With increasing design complexity, managing the input and output design files from the CAD tools is becoming extremely difficult. This is true especially when the data generated by CAD tools is enormous.

**Number of CAD tools** - CAD tool vendors are continuously supplying the designer with better CAD tools. Since many tools are incompatible in many ways, it takes a lot of time and effort to integrate them into a comprehensive design environment. This process takes a lot of time and effort especially when the CAD tools have different user-interfaces and file formats.

**Complexity of CAD tools** - Learning new CAD tools is not a trivial task; it involves a lot of time and effort. And if the designer does not continuously update his information about new and better tools he is left with a small set of CAD tools. To remain competitive the designer has to learn, master, and integrate new CAD tools to the existing CAD environment.

**Tool invocation and execution** - An integrated CAD environment will allow the designer to automatically invoke and execute CAD tools to perform a given task.

Three vital aspects of tool integration are visual, data, and control [SUNT, '90].

**Visual integration** - Visual integration implies that all the tools integrated should have the same look and feel. The interface between the designer and the tools should be homogeneous. This user interface must isolate the designer from the specifics of tool invocation and execution. The user must be able to choose from a list (usually icons) of tools or the execution environment must be able to choose one automatically based on the functionality of the tool. The interface should track and display the state of any on-going task including status of all related processes.

**Data integration** - Data integration can be classified as data linkage, data interchange, and data sharing as shown in Figure 3.

- **Data linkage** means establishing semantic relationships between pieces of information maintained by different tools. For example, Sun Microsystems' NSE Link Service 1.0 provides limited capability of this type [SUNT, '90].
- **Data interchange** means transferring information between tools in some mutually agreed upon representation. Examples of data interchange mechanism include window cut and paste, data import/export. Case Data Interchange Format (CDIF), is an example of a standard representation [SUNT, '90].
- **Data sharing** means that tools directly access data stored in a mutually accessible place. The Mentor Graphics' data repository approach is an example of data sharing that involves a common database schema and storage of data under a common data management system [WINK, '90].

**Control integration** - Control integration can be classified as interprocess control and meta control as shown in Figure 4.



Figure 3. Data integration. (a) Data linkage.  
(b) Data interchange. (c) Data sharing.

- **Interprocess control** means that a tool can cause another tool to perform some action.
- **Meta control** means causing a sequence of tool invocations and requisite data interchanges to accomplish some specific task automatically. Meta control can be implemented in terms of interprocess control, in which an 'agent' tool co-ordinates actions performed by other tools.

#### VI. The CAD Framework

We have already seen the need for CAD tool integration. This need has forced tool developers to create suites of tools that shield the designer from as much lower level detail as possible. Traditionally these suites were tightly integrated into a design environment [SIEW, '83] [BROW, '83]. CAD tools were bound into a monolithic entity. A problem with this approach was that tools were difficult to add or delete. This led to the creation of CAD Frameworks that are intended to be open architectures that support a large population of heterogeneous tools. CAD frameworks may be used to configure a set of VLSI tools and to develop appropriate interfaces to support schematic capture, simulation, timing verification, and test generation for ASIC design [HARR, '90]. It should act like a conduit between the



Figure 4. Control integration. (a) Interprocess control.  
(b) Meta control.

designer and the tools, matching the abilities of the tools to the needs of the designer. A framework should allow various tools to co-operate and work interactively with each other and with the designer. The designer need not learn all the subtle details of any tool; instead, the tools should present their general abilities to the designer as accurately and concisely as possible.

A generic CAD framework with its major components is shown in *Figure 5*. At a very high level the CAD framework can be viewed as having five major components described below [CAVI,'90]:

- A common user-interface which provides a consistent, graphical, and natural front end to the CAD tools.
- A design database containing design and library information which could be a centralized or distributed database.
- A design management database containing information on revisions, relationships, access authorizations, methodologies, and tools.
- A design data and process manager which utilizes the design management database to control design information and design process.
- CAD tools for all the phases of VLSI design.



Figure 5. A generic CAD framework.

#### Characteristics

Some important characteristics of CAD frameworks that directly effect the designer are summarized in this section.

A framework supports multiple users, thus the design can be divided among various designers. A distributed heterogeneous computing environment can be created thus allowing the designers to use tools that work under different computing environments.

The designer does not have to worry about the syntax of tool invocations and the semantics of tool commands since CAD frameworks will allow for automatic execution of tools. The designer is relieved of the burden of making available the proper data at the proper time to all the tools required in the design process. Once fully integrated into a framework all the tools will have the same look and feel making it easier for the designer to get accustomed to many different tools.

The designer can intermix design entry levels, for example hardware description languages (HDLs) and schematics, for specifying a design. CAD frameworks will allow for simulations of such intermixed design entries.

A framework supports different design styles and methodologies. It also allows an expert designer to record and save successful design methodologies, allowing less

experienced designers to create good designs using the knowledge of an expert designer. CAD frameworks combine top-down design with bottom-up schematic entry oriented design approach; this lets the designer tackle extremely complex IC designs. The designer can make arbitrary changes to the design at any stage and the framework will take care of design consistency by automatically propagating the effects of the changes to all related files.

Design complexity makes it impossible for the designer to foresee all situations where incompatibilities occur between the physical structure and the functional specifications. CAD frameworks will keep track of various versions of complex designs through all the phases of the development cycle while ensuring data integrity. Therefore, the designer can easily backtrack through all his previous design steps. He can also track the evolution of the design.

The framework eliminates long error-prone translations of data files between CAD tools since all the databases of the individual tools are either linked together by a common database or there is just a single database for all the tools.

CAD frameworks can be used for concurrent hardware and software design. Thus it will be possible to test software code on simulated hardware, permitting changes in either or both, to better meet the needs of the system [ADAM,'90]. It decreases the total turn-around time of the design process.

Until now, most of the decisions at every phase of the design were a matter of experience. With increasing complexities of the design process, just one wrong decision can prove fatal. The designer needs some decision support at the earlier stages of the design process. For example, if the designer decides on a particular floorplan he can get information about the affect of that floorplan on the final layout area of chip. Such decision support is provided by the framework.

CAD frameworks will allow the designers to work at a higher level of abstraction by allowing for simulations at the behavioral level. Designers need not become expert users of a baffling array of complex CAD tools, but instead need only be concerned with higher level design tasks. Designers can rectify potential problems before they happen at lower levels of design.

Knowledge required for good designs, such as the fundamentals of material properties, fabrication processes, device characteristics, microelectronics and circuit techniques, can also be built into the frameworks.

#### CAD Framework Initiative

Some vendors have come up with commercially available frameworks, for example Mentor Graphics' Falcon Framework, DEC's PowerFrame and Cadence's Design Framework II. Though there is general agreement over the basic definition of a framework, there are many different ways to implement the idea.

The CAD Framework Initiative (CFI), a body of CAD tool users, vendors, and system integrators was formed to supervise these ongoing framework efforts and lay down industry acceptable guidelines for design frameworks [CADF,'90]. CFI's purpose is to provide industry standard interfaces to CAD framework components, thus reducing the cost of combining multi-sourced CAD tools into an effective CAD system.

The CFI group defines a framework [CADF,'90] as:

"A software infra-structure that provides an environment where CAD tools are developed, integrated, and operated."

It further specifies that through a CAD framework, a user should be able to launch and manage tools; create, organize, and manage data; graphically view the entire design process; and perform design management tasks such as configuration management, version management, etc..

KBSC000035

**CFI and CAD tool integration**

CFI has come up with a seven layer conceptual model [FRAM,'90] of a framework (Figure 6). Out of these seven layers two layers (Levels 4 and 5) refer specifically to CAD tools. Level 4 allows for tool management which means that the tools have to be managed within the context of the overall design process. It specifies that the frameworks should supply models and services that describe inputs, outputs, options, invocation sequences, control files, etc. to manage tools. Usually tools can be integrated into any CAD system but the integration software has to deal with data translation between the tools. Level 5 allows for easy integration by separating the data descriptions from the tool integration programs.



Figure 6. CFI's conceptual model of frameworks.

**VII. Conclusion**

In this paper we have identified the ASIC development process and CAD tools required for an ASIC design process. Then we have shown the evolution of computer aided VLSI design from the point where individual CAD tools were available to perform some of the design tasks, to a unified design environment called the CAD Framework. CAD frameworks not only integrate CAD tools into an open environment but also automate the design process. We have identified the impact of CAD frameworks on the designer and thus hope that this paper helps the ASIC designers to introduce the benefits of CAD frameworks into their existing design environment.

We look forward to CAD frameworks that will support a fully automated design process. The designer need only be involved in the process of specification capture and feeding behavioral/functional specifications to the CAD system. By the end of this decade we hope that there will be accepted standards for integrating not only CAD tools but tools that will encompass all other IC related areas such as manufacturing, control systems, process and device modelling, etc.

**References**

- [ADAM,'90] Adams, Charlotte, "CAD Frameworks: Putting it all together", *Military and Aerospace Electronics*, pp. 33-38, July 1990.
- [BROW,'83] Brown, H., et. al., "Palladio: An Exploratory Environment for Circuit Design", *IEEE Computer*, December 1983.
- [BUSH,'89] Bushnell, M.L. and Director, S.W., "Automated Design Tool Execution in the Ulysses Design Environment", *IEEE Transc. on Computer Aided Design*, vol. 8, no. 3, pp. 279-287, March 1989.
- [CADF,'90] TCC-Approved Draft Proposal, "CAD Framework Users, Goals and Objectives", 1990.
- [CAVI,'90] Cavin, R.K. and Hilbert, J.L. "Design of

Integrated Circuits: Directions and Challenges", *Proceedings of the IEEE*, vol. 78, no. 2, pp. 418-435, Feb.1990.

[DANI,'89] Daniell, J. and Director, S.W., "An Object Oriented approach to CAD Tool Control within a Design Framework", *Proceedings IEEE 26th. Design Automation Conference*, pp. 197- 202, 1989.

[FIDU,'90] Fiduk, K.W., et al., "Design Methodology Management -A CAD framework Initiative Perspective", *Proceedings IEEE 27th. Design Automation Conference*, pp. 278-283, 1990.

[FRAM,'90] Cadence's catalogue, "Framework Technology for the 1990s", 1990.

[HARR,'90] Harrison, D.S., et al., "Electronic CAD Frameworks", *Proceedings of the IEEE*, vol. 78, no. 2, pp. 393-417, Feb. 1990.

[KEUT,'89] Keuterer, Kurt, "Three Competing Design Methodologies for ASICs: Architectural Synthesis, Logic Synthesis and Module generation", *Proceedings IEEE 26th. Design Automation Conference*, pp. 308-313, 1989.

[LEUN,'88] Leung, S.S., Fisher, P.D., and Shanblatt, M.A., "A conceptual framework for ASIC design", *Proceedings of the IEEE*, vol. 76, no. 7, pp. 741-755, July 1988.

[NEWT,'86] Newton, A. R., and Sangiovanni-Vincentelli, A. L., "Computer-Aided Design for VLSI circuits", *IEEE Computer*, pp. 38-60, April 1986.

[SCOT,'85] Scott, W. S., et al., "1986 VLSI Tools: Still More Works by the Original Artists", *Report No. UCB/CSD 86/272*, Univ. of California, Berkeley, December 1985.

[SIEW,'83] Siewiorek, D. P. , et al., "DEMETER-A Design Methodology and Environment", *Tech. report CMUCAD-83-5*, Electrical and Comp. Eng. Dept., Carnegie Mellon University, 1983.

[STRO,'88] Strojwas, A. J., and Director, S. W., "VLSI: linking design and manufacturing", *IEEE Spectrum*, pp. 24-28, Oct. 1988.

[SUNT,'90] "CASE Integration Frameworks", *SunTech Journal*, Nov. 1990.

[WINK,'90] Winkler, E., "EDA Firms Find Several Roads to Frameworks", *Electronic News*, June 25, 1990.



# Dictionary of Computing

- ▼ The most comprehensive computing dictionary ever published
- ▼ More than 18,000 entries

DEF083932

**Limitation of Liability**

While the Editor and Publisher of this book have made reasonable efforts to ensure the accuracy and timeliness of the information contained herein, neither the Editor nor the Publisher shall have any liability with respect to loss or damage caused or alleged to be caused by reliance on any information contained herein.

Copyright © 1994 by International Business Machines Corporation. All rights reserved. Printed in the United States of America. Except as permitted under the United States Copyright Act of 1976, no part of this publication may be reproduced or distributed in any form or by any means, or stored in a data base or retrieval system, without the prior written permission of the publisher.

7 8 9 0 DOC/DOC 9 9 8

ISBN 0-07-031488-8 (HC)  
ISBN 0-07-031489-6 (PBK)

*The sponsoring editor for this book was Daniel A. Gonneau and the production supervisor was Thomas G. Kowalczyk.*

*Printed and bound by R. R. Donnelley & Sons Company.*

**Tenth Edition (August 1993)**

This is a major revision of the *IBM Dictionary of Computing*, SC20-1699-8, which is made obsolete by this edition. Changes are made periodically to the information provided herein.

It is possible that this material may contain reference to, or information about, IBM products (machines and programs), programming, or services that are not announced in your country. Such references or information must not be construed to mean that IBM intends to announce such IBM products, programming, or services in your country. Comments may be addressed to IBM Corporation, Department E37/656, P. O. Box 12195, Research Triangle Park, NC 27709.

**International Edition**

Copyright © 1994 by International Business Machines Corporation. Exclusive rights by McGraw-Hill, Inc. for manufacture and export. This book cannot be re-exported from the country to which it is consigned by McGraw-Hill. The International Edition is not available in North America.

When ordering this title, use ISBN 0-07-113383-6.

**compound string**

[129]

**computer-aided design (CAD)**

**compound string** A type of string designed to simplify national language support by allowing text to be displayed without hard-coding language-dependent attributes such as character sets and text.

**compress** (1) In a character string, to reduce the space taken on a data medium by repetitive characters. (T) (2) To save storage space by eliminating gaps, empty fields, redundancy, or unnecessary data to shorten the length of records or files. (3) To move files, libraries, or folders together on disk to create a continuous area of unused space.

**compressed audio** Audio resulting from the process of digitally encoding and decoding up to 40 seconds of voice-quality audio for each individual videodisc, resulting in a potential for over 150 hours of audio per 12-inch videodisc. Synonymous with still-frame audio.

**compressed disk file** In System/36, a file that contains unprocessed records.

**compressed encoding** (1) A process in which a contiguous string of bits, characters, or data units is reduced to a shorter string in such a way that a second contiguous string, yielding the same short string, cannot be found and the process cannot be reversed. (2) A process in which variable-length messages are reduced to a shorter, fixed-length message.

**compressed pattern storage** Storage that holds the extended fonts for the 3800 printer.

**compressed video** Video resulting from the process of digitally encoding and decoding a video image or segment using a variety of computer techniques to reduce the amount of data required to represent the content accurately.

**compression** (1) The process of eliminating gaps, empty fields, redundancies, and unnecessary data to shorten the length of records or blocks. (2) In SNA, the replacement of a string of up to 64 repeated characters by an encoded control byte to reduce the length of the data stream sent to the LU-LU session partner. The encoded control byte is followed by the character that was repeated (unless that character is the prime compression character). See also compaction, string control byte. (3) In Data Facility Hierarchical Storage Manager, the process of moving data instead of allocated space during migration and recall in order to release unused space. (4) Contrast with decompression.

**compressor** An electronic device that compresses the volume range of a signal. See also compandor, expandor.

**COM printer** A page printer that produces on a photographic film a microimage of each page. Synonymous with computer output microfilm printer. (T) (A)

**compromise** In computer security, a violation of the security policy of a system in which unauthorized intentional or unintentional disclosure, modification, or destruction, or loss, of an object, may have occurred.

**compromise net** A network, used in conjunction with a hybrid coil to balance a subscriber's loop, that is adjusted for an average loop length or an average subscriber's set, or both, to secure compromise (not precision) isolation between the two directional paths of the hybrid.

**compromising emanations** In computer security, unintentional intelligence-bearing signals that may convey data and that, if intercepted and analyzed, may compromise sensitive information being processed or transmitted by a computer system.

**COMPUSEC** Computer security.

**computational stability** The degree to which a computational process remains valid when subjected to effects such as errors, mistakes, or malfunctions. (A)

**compute mode** That operating mode of an analog computer during which the solution is in progress. Synonymous with operate mode. (T)

**computer** A functional unit that can perform substantial computations, including numerous arithmetic operations and logic operations without human intervention during a run. In information processing, the term computer usually describes a digital computer. A computer may consist of a stand-alone unit or may consist of several interconnected units. (T)

**computer abuse** In computer security, a willful or negligent unauthorized activity that affects the availability, confidentiality, or integrity of computer resources. Computer abuse includes fraud, embezzlement, theft, malicious damage, unauthorized use, denial of service, and misappropriation. See also information system abuse.

**computer-aided (CA)** Pertaining to a technique or process in which part of the work is done with the assistance of a data processing system. Synonymous with computer-assisted. (T)

**computer-aided design (CAD)** The use of a computer to design or change a product, tool, or machine, such as using a computer for drafting or illustrating.

**Note:** Sometimes, CAD and CAM are used together and expressed as CAD/CAM. (T)

**computer-aided engineering (CAE)**

[130]

**computer generation**

**computer-aided engineering (CAE)** Analysis of a design to check for basic errors, or to optimize manufacturability, performance or economy; for example, by comparing various possible materials or designs.

**Note:** Information from the CAD/CAM design database is used to analyze the functional characteristics of a part, product under design, and to simulate its performance under various conditions. (T)

**computer-aided industry (CAI)** The use of computer systems to assist in the operation of an industry. (T)

**computer-aided instruction (CAI)** The use of a computer to assist human instruction. (T) Synonymous with computer-assisted instruction.

**computer-aided manufacturing (CAM)** The use of computer technology to direct and control the manufacturing process. (T)

**computer-aided planning (CAP)** All activities for preparation of the basic data about production processes by usage of computer technology. (T)

**computer-aided publishing** Synonym for electronic publishing. (T)

**computer-aided quality assurance (CAQ)** The use of computer technology to plan, monitor and control processes, parts and products throughout all phases of the product life cycle; this includes an overall quality report system from design to field performance and from shop floor to the management. (T)

**computer-aided retrieval (CAR)** Systems that combine the document storage capabilities of micrographics with the indexing and retrieval capabilities of a computer database.

**computer-aided software engineering (CASE)** (1) The automation of well-defined methodologies that are used in the development and maintenance of products. These methodologies apply to nearly every process or activity of a product development cycle, examples of which include project planning and tracking, product designing, coding, and testing. (2) A set of computer-based development tools to automate certain portions of methodologies. Thus, CASE tools work within a methodology rather than compose a methodology themselves. See also CCASE, ICASE.

**computer-animated graphics** In multimedia applications, graphics animated by means of a computer, rather than videotape or film.

**computer architecture** (1) The logical structure and functional characteristics of a computer, including the

interrelationships among its hardware and software components. (T) (2) The organizational structure of a computer system, including hardware and software. (A) (3) See also hypercube, parallel processor architecture.

**computer-assisted** Synonym for computer-aided (CA). (T)

**computer-assisted instruction (CAI)** Synonym for computer-aided instruction.

**computer-assisted publishing** Synonym for electronic publishing. (T)

**computer-based training** Synonym for computer-assisted instruction.

**computer center** A facility that includes people, hardware, and software, organized to provide information processing services. Synonymous with data processing center, installation. (T) (A)

**computer conferencing** Computerized communication that allows people distant from each other to enter and receive text and graphic messages via interconnected terminals. (T) See also conference call, teleconferencing, videoconferencing.

**computer crime** (1) In computer security, a crime committed through the use of software or data. (T) (2) A crime committed through the use of software or data residing in a computer. (T) (A)

**computer cryptography** In computer security, the use of a cryptographic algorithm in a computer to perform encryption and decryption to protect information or to authenticate users, sources, or information.

**computer edit system** A video editing system, controlled by a computer and connected to machines for recording and playback.

**computer-dependent language** Synonym for computer-oriented language.

**computer fraud** (1) In computer security, a computer crime that involves deliberate misrepresentation or alteration of data in order to obtain something of value, usually for monetary gain. (T) (2) Deception by means of a computer, deliberately practiced in order to secure unfair or unlawful gain. (A)

**computer generation** A category in a historical classification of computers based mainly on the technology used in their manufacture; for example, first generation based on relays or vacuum tubes, the second on transistors, the third on integrated circuits. (T)

**operating time****[479]****operations analysis**

**operating time** (1) That part of operable time during which a functional unit is operated. (A) (2) Contrast with idle time.

**operating voltage indicator** On a calculator, a device giving a visual signal to indicate that the correct voltage is set for a main-powered machine or that the battery is insufficiently charged in a battery-powered machine. (T)

**operation** (1) A well-defined action that, when applied to any permissible combination of known entities, produces a new entity; for example, the process of addition in arithmetic; in adding five and three and obtaining eight, the numbers five and three are the operands, the number eight is the result, and the plus sign is the operator indicating that the operation performed is addition. (I) (A) (2) A defined action, namely, the act of obtaining a result from one or more operands in accordance with a rule that completely specifies the result for any permissible combination of operands. (A) (3) A program step undertaken or executed by a computer; for example, addition, multiplication, extraction, comparison, shift, transfer. The operation is usually specified by the operator part of an instruction. (A) (4) The event or specific action performed by a logic element. (A) (5) An action performed on one or more data items, such as adding, multiplying, comparing, or moving. (6) In object-oriented design or programming, a service that can be requested at the boundary of an object. Operations include modifying an object or disclosing information about an object.

**operational amplifier** A high-gain amplifier connected to external elements to perform specific operations or functions. (I) (A)

**Operational Assistant** In the AS/400 system, a part of the operating system that provides a set of menus and displays for end users to do commonly performed tasks, such as working with printer output, messages, and batch jobs.

**operational diskette** Synonym for working diskette.

**operational environment** (1) The physical environment; for example, temperature, humidity, and layout. (2) All of the IBM-supplied basic functions and the user programs that can be executed by a store controller to enable the devices in the system to perform specific operations. (3) The collection of IBM-supplied store controller data, user programs, lists, tables, control blocks, and files that reside in a subsystem store controller and control its operation. (4) See also configuration image.

**operational expression** In PL/I, an expression that consists of one or more operations.

**operational key** Synonym for session cryptography key.

**operational mode** See asynchronous balanced mode, asynchronous response mode, normal response mode.

**operational rights** The authority to use an object and to look at its description.

**operational sign** An algebraic sign associated with a numeric data item or a numeric literal that indicates whether the item is positive or negative.

**operational unit (OU) number** In System/36, the number that corresponds to the line connector, located on the back of the system unit, to which a line is attached.

**operation code** (1) A code for representing the operation parts of the machine instructions of a computer. (T) (2) A code used to represent the operations of a computer. (3) In SSP-ICF, a code used by a System/36 application program to request SSP-ICF data management or the subsystem to perform an action; for example, the operation \$\$SEND asks that data be sent. (4) In RPG, a word or abbreviation, specified in the calculation specifications, that identifies an operation.

**operation code trap** A specific value that replaces the normal operation part of a machine instruction at a particular location to cause an interrupt when that machine instruction is executed. (T)

**operation control language (OCL)** A programming language used to code operation control statements.

**operation control statement** A statement in a job or job step that is used in identifying the job or describing its requirements to the operating system.

**operation decoder** A device that selects one or more control channels according to the operation part of a machine instruction. (A)

**operation expression** An expression containing one or more operators.

**operation mode** The normal working state of a product or system. See also maintenance mode.

**operation part** (1) The part of a machine instruction or microinstruction that specifies the operation to be performed. (T) (2) The part of an instruction that specifies the operation to be performed. Synonymous with function part, operator part. (A) (3) See also implied addressing.

**operations analysis** Synonym for operations research.

## RTAM generation

[591]

running open

**RTAM generation** The process of assembling selected RTAM facilities and link editing them into VS1.

**RTB** Response/throughput bias.

**RTG** Route Table Generator.

**RTM** Realtime monitor.

**RTTY** Radio teletypewriter telecommunications.

**RTV** Real-Time Video.

**RU** Request/response unit.

**rubber-banding** In computer graphics, moving the common ends of a set of straight lines while the other ends remain fixed. (I) (A) See Figure 129.



Figure 129. Rubber-Banding

**rubber-band outline** In the AIX operating system, a window with a moveable outline.

**rub-out character** Synonym for delete character.

**RU chain** In SNA, a set of related request/response units (RUs) consecutively transmitted on a particular normal or expedited data flow. The request RU chain is the unit of recovery. If one RU in the chain cannot be processed, the entire chain must be discarded.

**Note:** Each request unit belongs to only one chain, which has a beginning and an end indicated through control bits in request/response headers within the RU chain. Each RU can be designated as first-in-chain (FIC), last-in-chain (LIC), middle-in-chain (MIC), or only-in-chain (OIC). Response units and expedited-flow request units are always sent as only-in-chain.

**rule** A solid or patterned line of any weight, extending horizontally or vertically across a column or row.

**rule-based system** A computer system which performs inferences by applying a set of if then rules to a

set of facts following given procedures. Synonymous with production system. (T)

**rule interpreter** Synonym for inference engine. (T)

**ruler line** A line that indicates where the left and right margins and any tab stops are set. (T)

**run** (1) A performance of one or more jobs. (I) (A) (2) A performance of one or more programs. (I) (A) (3) To cause a program, utility, or other machine function to be performed.

**runaway task** In CICS, a task that does not relinquish control within an interval of time defined by the user.

**RUN disk** The virtual disk that contains the VTAM, NetView, and VM/SNA console support (VSCS) load libraries, program temporary fixes (PTFs) and user-written modifications from the ZAP disk. See BASE disk, DELTA disk, MERGE disk, ZAP disk.

**rundown** In multimedia, an outline of the content of a video program for which a script is inappropriate or impossible, such as an interview.

**run duration** Synonym for running time.

**run file** In the AIX operating system, synonym for load module.

**run-length coding** A technique for compressing data that avoids having to code repeatedly data elements of the same value; instead, the value is coded once, along with the number of times for it to be repeated.

**run list** In VM/SP, a list of virtual machines that are receiving a queue slice on the processing unit. The virtual machine currently executing is called the runuser. When virtual machines are dropped from the run list, replacement is made from the eligible list. See also dispatch list, eligible list.

**running foot** (1) Synonym for footer. (T) (2) A footing that is repeated above the bottom margin area on consecutive pages or on consecutive odd-numbered or even-numbered pages in the text area of the page. Synonymous with footer.

**running heading** (1) Synonym for header. (T) (2) A heading that is repeated below the top margin area on consecutive pages or on consecutive odd-numbered or even-numbered pages in the text area of the page.

**running open** In telegraph applications, a term used to describe a machine connected to an open line or a line without battery (constant space condition). A telegraph receiver under such a condition appears to

*A Merriam-Webster®*

# Webster's Ninth New Collegiate Dictionary

Almost 160,000 entries and 200,000 definitions.

- Entries for words often misused or confused include a clear, authoritative guide to good usage.
- In an exclusive new feature — entries are dated. How old is a word? When was it first used? The answer is here, but in no other American dictionary.
- The newest in the famous Collegiate series, the most widely approved dictionary for home, school and office.



A GENUINE MERRIAM-WEBSTER

The name *Webster* alone is no guarantee of excellence. It is used by a number of publishers and may serve mainly to mislead an unwary buyer.

A *Merriam-Webster®* is the registered trademark you should look for when you consider the purchase of dictionaries or other fine reference books. It carries the reputation of a company that has been publishing since 1831 and is your assurance of quality and authority.

Copyright © 1987 by Merriam-Webster Inc.

Philippines Copyright 1987 by Merriam-Webster Inc.

Library of Congress Cataloging in Publication Data  
Main entry under title:

Webster's ninth new collegiate dictionary.

Based on Webster's third new international  
dictionary.

Includes index.

1. English language—Dictionaries. I. Merriam-  
Webster Inc.

PE1628.W5638 1987 423 86-23801

ISBN 0-87779-508-8

ISBN 0-87779-509-6 (indexed)

ISBN 0-87779-510-X (deluxe)

Abbre

Webster's Ninth New Collegiate Dictionary principal copyright 1983

COLLEGIATE trademark Reg. U.S. Pat. Off.

All rights reserved. No part of this book covered by the copyrights hereon may be reproduced or copied in any form or by any means—graphic, electronic, or mechanical, including photocopying, taping, or information storage and retrieval systems—without written permission of the publisher.

Made in the United States of America

2223242526RMcN87

DEF085291

as-so-ci-a-ble \-sō-sh(ē)-bəl, -shē-ə-ble\ adj (1855) : capable of being associated, joined, or connected in thought  
as-so-ci-a-tion \-sō-sh(ē)-shən\ vb -at-ed, -at-ing [ME *associatiō* associated, fr. L. *associatus*, pp. of *associare* to unite, fr. *ad-* + *sociare* to join, fr. *socius* companion — more at *SOCIAL*] 1 : to join as a partner, friend, or companion 2 : to keep company with : ATTEND 3 : to join or connect together : COMBINE; specifically : to subject to chemical association 4 : to bring together or into relationship in any of various intangible ways (as in memory or imagination) ~ vi 1 : to come or be together as partners, friends, or companions 2 : to combine or join with others parts; UNIT ~ syn see JOIN  
as-so-ci-ate \-sō-sh(ē)-ēt, -shāt, -shōt\ adj (14c) 1 : closely connected (as in function or office) with another 2 : closely related esp. in the mind 3 : having secondary or subordinate status (~ membership in a society) ~ like \lik\ n (1533) 1 : one associated with another: as PARTNER, COLLEAGUE 2 : COMPANION, COMRADE 2 often cap : degree conferred esp. by a junior college (~ in arts) — as-so-ci-a-tion-ship \-shēp\ n  
associate professor n (1822) : a member of a college or university faculty who ranks above an assistant professor and below a professor — associate professorship n  
as-so-ci-a-tion \-sō-sh(ē)-shōn, -shē-ən\ n (1535) 1 a : the act of associating b : the state of being associated : COMBINATION, RELATIONSHIP 2 : an organization of persons having a common interest : SOCIETY 3 : something linked in memory or imagination with a thing or person 4 : the process of forming mental connections or bonds between sensations, ideas, or memories 5 : the aggregation of chemical species to form (as with hydrogen bonds) loosely bound complexes 6 : a major unit in ecological community organization characterized by essential uniformity and usu. by two or more dominant species — as-so-ci-a-tion-al \-shēnl, -shēn-\ adj  
association area n (ca. 1909) : an area of the cerebral cortex that functions in linking and coordinating the sensory and motor areas  
association football n (1873) — SOCCER  
as-so-ci-a-tion-ism \-sō-shē-ən-izm, -shē-ən-izm\ n (1875) : a reductionist school of psychology that holds that the content of consciousness can be explained by the association and reassociation of irreducible sensory elements — as-so-ci-a-tion-ist \-shē-ən-ist\ adj  
as-so-ci-a-tive \-sō-sh(ē)-ētiv, -shātiv, -shōtiv\ adj (1812) 1 : of or relating to association esp. of ideas or images 2 : dependent on or acquired by association or learning 3 : combining elements such that when the order of the elements is preserved the result is independent of the grouping (addition is ~ since  $(a + b) + c = a + (b + c)$ ) — as-so-ci-a-tiv-ly \-shē-ən-ē\ adv — as-so-ci-a-tiv-ty \-shōtiv-ē\ n  
associative learning n (1957) : a learning process in which discrete ideas and perceptions become linked to one another  
associative neuron n (1935) : a neuron that conveys impulses from one neuron to another  
assail \-sō-lēl\ v [ME *assaien*, fr. OF *assoldre*, fr. L. *absolvere* 'to absolve'] (13c) 1 *archaic* : ABSOLVE, PARDON 2 *archaic* : ACQUIT, CLEAR 3 *archaic* : EXPIATE — as-sail-ment \-mēnt\ n, *archaic*  
as-so-nance \-sō-nans\ n [F. *Fr. L. *assonare* to answer with the same sound, fr. ad- + *sonare* to sound — more at SOUND] (1727) 1 : resemblance of sound in words or syllables 2 a : relatively close juxtaposition of similar sounds esp. of vowels b : repetition of vowels without repetition of consonants (as in *story* and *holy*) used as an alternative rhyme in verse — as-so-nant \-nānt\ adj or n  
as soon as conj (14c) : immediately at or just after the time that  
as-sort \-sōrt\ v [MF *assortir*, fr. a- (fr. L. *ad-*) + *sorte* sort] vt (15c) 1 : to distribute into groups of a like kind : CLASSIFY 2 : to supply with an assortment (as of goods) ~ vi 1 : to agree in kind : HARMONIZE 2 : to keep company: ASSOCIATE — as-sort-er n  
as-sor-ta-tive \-sōr-tātiv, -shātiv, -shōtiv\ adj (1897) : being nonrandom mating based on like or unlike characteristics  
as-sorted \-sōr-tēd\ adj (ca. 1797) 1 : suited by nature, character, or design (an ill-assorted pair) 2 : consisting of various kinds as-sort-ment \-sōr-tēmənt\ n (ca. 1611) 1 : the act of assorting 2 : the state of being assorted 2 : a collection of assorted things or persons  
as-surge \-sōrj\ also \-sōrzh\ or \-sōrzh\ v [ME *assugren*, fr. OF *assougier*, fr. (assumed) VL *assuavire*, fr. L. *assuare* 'to assuage' — more at *SWEET*] (14c) 1 : to lessen the intensity (something that pains or distresses) : EASE 2 : PACIFY, QUIET 3 : to put an end to by satisfying : APPEASE, QUENCH (he assuaged his hunger with a sandwich) ~ syn see RELIEVE — as-surge-ment \-mēnt\ n  
as-sus-ive \-sōsēv, -ziv\ adj (1708) : SOOTHING, CALMING  
as-sum \-sōm\ v as-sumed; as-sum-ing [ME *assumere* fr. L. *assumere* 'to take up, to sumere to take — more at CONSUME'] (15c) 1 : to take up or in : RECEIVE 2 : to take into partnership, employment, or use 2 : to take to or upon oneself : UNDERTAKE 3 : PUT ON DON 3 : SEIZE, USURP 4 : to pretend to have or be : FEIGN (*assumed* an air of confidence in spite of her dismay) 5 : to take as granted or true : SUPPOSE 6 : to take over (the debts of another) as one's own — as-sum-abil-i-ty \-sōm-əbil-ē\ n — as-sum-able \-sōm-ə-bal\ adj — as-sum-ibil-i-ty \-sōm-əbil-ē\ adj  
syn ASSUME, AFFECT, PRETEND, SIMULATE, FEIGN, COUNTERFEIT. SHAM means to put on a false or deceptive appearance. ASSUME often implies a justifiable motive rather than an intent to deceive. AFFECT implies making a false show of possessing, using, or feeling; PRETEND implies an overt and sustained false appearance. SIMULATE suggests a close imitation of the appearance of something; FEIGN implies more artful invention than PRETEND, less specific mimicry than SIMULATE. COUNTERFEIT implies achieving the highest degree of verisimilitude of any of these words; SHAM implies an obvious falseness that fools only the gullible.  
as-sum-ing adj (1695) : PRETENTIOUS, PRESUMPTUOUS  
as-sump-ti-ti-on \-sōp-tē-shən\ [NL, *he undertook*, fr. L. *assumere* to undertake] (1590) 1 a : a common-law action alleging damage from breach of agreement b : an action to recover damages for breach of contract or promise 2 : a promise or contract not under seal on which an action of assump-tion may be brought*

asth-ma \az-mə-  
skin to *L. anima* (i.e. *spirit*) that is accompaniment and often by *at* *Bri-as-adj-ni* (1849) : as though conj. (1) as-tig-mat-ic \at'ig-mat'ik (1849) 1 : astigmatism : showing incusism, a disarrangement of the eye 2 : astigmatism : system (as a telescope) in a local defect of vision and esp. to correct the blurred vision of the astigmatism (1849) 2 : UP as to prep (14c) error 2 : Acc as-ton-ished \a-stən'ish'd : deprived, struck with consternation as-ton-ish \a-stən'ish' : as-ton-ish-ton, fr. OFC *é* to thunder) 1 : to strike with wonder or surprise as-ton-ish-ing \a-stən'ish-ing' : as-ton-ish-ment \a-stən'ish-mənt : astonished b : wonder or surprise as-ton-oud \a-stən'oud : overwhelmed as-ton-oud \a-stən'oud (14c) PRIDE as-found-ing \a-stən'oud-ing : as-ton-ay or astro-c as-ton-ay : more (astrophysics) as-trad-ile \a-stəd'ile : both sides : As as-trad-ile prep as-tra-gal \a-stəg'əl (1563) 1 : on the edge of as-tra-ga-nin \a-stəg'ə-nin : skin to Ok or bones of the as-trak-han or U.S.S.R.] (1711) usw. wool, cur as-tral \a-stər'əl : at STAR] (1601) stars : STARRY consisting of : above the tangent in station or position as-tray \a-strə'ē : stray — more ING 2 : in error as-tride \a-stri'd : horse ~) 2 : as-tride prep (1) : placed or lying NING, BRIDGING as-trin-geant \a-stri'ng' : gene prep. of a more at STRA tissues : STYPTIC : astringent ments); also : *adv* as-trin-geant \a-stri'ng' : as-trro-biolog \a-stro-bi'ə-ləg' : bio-logical \a-bi'ə-ləg' : as-trro-cy-te \a-stro'kə-tē : neuroglia) as-trro-cy-to-ma 1923) : a nerve as-trro-dome \a-stro-dōm' : upper surface of the celestial sphere as-trro-labe \a-stro-lāb' : MF & ML *astrolobium*, *d. lambanein* to compact insculpt the pc the invention as-trro-lo-ger \a-stro-lo'gər : practitioner as-trro-logy \a-stro'lojē : MF, fr. L. *astrolōgī* (14c) nation of the and planets events by the as-trro-log-ic \a-stro'loj'ik : as-trro-log-ic



**des-cant** \dēs-kānt\ *n* [ME *dyscant*, fr. ONF *descant*, fr. ML *discantus* fr. L *dis-* + *cantus* song — more at *CHANT*] (14c) 1 : a melody or counterpoint sung above the plainsong of the tenor 2 : the art of composing or improvising contrapuntal part music; also : the music so composed or improvised *e* : SOPRANO, TREBLE *d* : a superimposed counterpoint to a simple melody sung typically by some or all of the sopranos 2 : discourse or comment on a theme

**des-cant** \dēs-kānt, dēs- \ *n* (15c) 1 : to sing or play a descant; broadly: SING 2: COMMENT, DISCOURSE

**des-cend** \dēs-endl\ *v* [ME *descenden*, fr. OF *descendre*, fr. L *descendere*, fr. *de-* + *scendere* to climb — more at *SCAN*] *vi* (14c) 1 : to pass from a higher place or level to a lower one (*~ed from the platform*) 2 : to pass in discussion from what is logically prior or more comprehensive 3 *a* : to come down from a stock or source : DERIVE — used in passive (*was ~ed from an ancient family*) *b* : to pass by inheritance (an heirloom that has *~ed* in the family) *c* : to pass by transmission (songs *~ed* from early ballads) 4 : to incline, lead, or extend downward (the road *~s* to the river) 5 : to swoop or pounce down or make a sudden attack (the plague *~ed upon them*) 6 : to proceed in a sequence or gradation from higher to lower or from more remote to nearer or more recent 7 *a* : to lower oneself in status or dignity: STOOP *b* : to worsen and sink in condition or estimation *~* *vt* 1 : to pass, move, or climb down or down along 2 : to extend down along — *descendible* \'-sen-də-bəl\ *adj*

**de-scen-dant** or **de-scen-dent** \dēs-ən-dənt\ *adj* [MF & L; MF *descendant*, fr. L *descendent-*, *descendens*, pp. of *descendere*] (1572) 1 : moving or directed downward 2 : proceeding from an ancestor or source

**de-scen-dant** or **de-scen-dent** \dēs-ən-dənt\ *n* [F & L; F *descendant*, LL *descendent-*, *descendens*, fr. L] (1600) 1 : one descended from another or from a common stock 2 : one deriving directly from a precursor or prototype

**de-scen-der** \dēs'-ən-dər, dēs- \ *n* (1802) : the part of a lowercase letter (as *p*) that descends below the main body of the letter; also : a letter that has such a part

**de-sen-sion** \dēs'-ən-shən\ *n*, *archaic* (14c): DESCENT 2

**de-sen-t** \dēs'-ənt\ *n* [ME, fr. MF *descente*, fr. OF *descendre*] (14c) 1 : derivation from an ancestor : BIRTH, LINEAGE (of French *~*) 2 : transmission or devolution of an estate by inheritance usu. in the descending line *c* : the fact or process of originating from an ancestral stock *d* : the shaping or development in nature and character by transmission from a source : DERIVATION 2 : the act or process of descending 3 : a step downward in a scale of gradation; *specif*: one generation in an ancestral line or genealogical scale 4 *a* : an inclination downward : SLOPE *b* : a descending way (as a downgrade or staircase) *c* *obs*: the lowest part 5 *a* : ATTACK, INVASION *b* : a sudden disconcerting appearance (as for a visit) 6 : a downward step (as in station or value): DECLINE (*~ of the family to actual poverty*)

**de-scrib** \dēs'-skrib\ *v* *de-scribed*; *de-scribing* [L *describere*, fr. *de-* + *scribere* to write — more at *SCRIBE*] (15c) 1 : to represent or give an account of in words (*~ a picture*) 2 : to represent by a figure, model, or picture: DELINEATE 3 *obs*: *DISTRIBUTE* 4 : to trace or traverse the outline of (*~ a circle*) 5 *archaic* : OBSERVE, PERCEIVE — *de-scribable* \'-skrib-bə-bəl\ *adj* — *de-scriber* *n*

**de-scrip-tion** \dēs'-krip-shən\ *n* [ME *descripcoun*, fr. MF & L; MF *descriptiōn*, fr. L *descriptio*, fr. *descriptus*, pp. of *describere*] (14c) 1 *a* : an act of describing; *specif*: discourse intended to give a mental image of something experienced (as a scene, person, or sensation) *b* : a descriptive statement or account (a fascinating *~* of his adventures) 2 : kind or character esp. as determined by salient features (opposed to any tax of so radical a *~*) *syn* see *TYPE*

**de-scrip-ti-ve** \dēs'-krip-tiv\ *adj* (1751) 1 : serving to describe (a *~ account*) 2 : referring to, constituting, or grounded in matters of observation or experience (the *~ basis of science*) 3 *of a modifier* a : expressing the quality, kind, or condition of what is denoted by the modified term (hot in "hot water" is *~ adjective*) *b* : NONRESTRICTIVE 4 : of, relating to, or dealing with the structure of a language at a particular time usu. with exclusion of historical and comparative data (*~ linguistics*) — *de-scrip-ti-vel* *adv* — *de-scrip-ti-veness* *n*

**de-scrip-tor** \dēs'-krip-tor\ *n* (1951) : something (as an index term) used to identify an item (as a subject or document) esp. in an information retrieval system

**de-scri** \dēs-skri\ *v* *de-scribed*; *de-scribing* [ME *descrien*, fr. MF *descrier* to proclaim, *decriy*] (14c) 1 *a* : to catch sight of *b* : to find out : DISCOVER 2 *obs*: to make known : REVEAL

**de-scri** *n*, *obs*: *discovery or view from afar*

**Des-de-mo-na** \dez-də-mō-nə\ *n* : the wife of Othello in Shakespeare's *Othello*

**de-s-e-cra-te** \dēs-i-krāt\ *v* *-cra-ted*; *-cra-ting* [*de-* + *-se-crate* (as in *conse-crate*)] (1677) 1 : to violate the sanctity of : PROFANE 2 : to treat irreverently or contemptuously often in a way that provokes outrage on the part of others (the kind of shore development . . . that has *desecrated* so many waterfronts — John Fischer) — *de-s-e-cra-tor* or *desec-  
ra-tor* \'-krā-tör\ *n*

**de-s-e-cra-tion** \dēs-i-krā-shən\ *n* (1717) : an act or instance of *desecrate*ing : the state of being *desecrated*

**de-seg-ri-ga-tion** \dēs'-seg-ri-gā-shən\ *n* (1952) : to eliminate segregation in; *specif*: to free of any law, provision, or practice requiring isolation of the members of a particular race in separate units *~* *vt* : to bring about *desegregation*

**de-seg-ri-ga-tion** \dēs'-seg-ri'-gā-shən\ *n* (1951) 1 : the act or process or an instance of *desegregating* 2 : the state of being *desegregated*

**de-se-lec-t** \dēs'-ə-lekt\ *vt* (1965) : to dismiss (a trainee) from a training program

**de-sen-si-tize** \dēs'-sen-ti(z)-, -sən-ti(z)\ *vt* (1898) 1 : to make (a sensitized or hypersensitive individual) insensitive or nonreactive to a sensitizing agent 2 : to make (a photographic material) less sensitive or completely insensitive to radiation 3 : to make emotionally insensitive or callous; *specif*: to extinguish an emotional response (as of fear, anxiety, or guilt) to stimuli that formerly induced it — *de-sen-si-ti-zation* \dēs'-ən-si-tā-zā-shən, -sən-si-tā-zā-shən *n* — *de-sen-si-tizer* \dēs'-ən-si-tīzər\ *n* [ME, fr. OF, fr. LL *desertum*, fr. L, neut. of *deserere* pp. of *deserere* to desert, fr. *de-* + *serere* to join together — more at *desert* *n*]

about kitten, F table further ast  
 out chin bet easy go  
 sing go low boy thin  
 yet vision k ee ee ee

to Pronunciation

DEF085294



sentinel *vt* -held *or* -held, *held* *adj* 1 : over as a sentinel 2 : to furnish with a sentinel 3 : to post as sentinel *n* 1 : sentry *n* pl sentries *pl* [perh. fr. *obs.* *sentry* (*sanctuary, watchtower*)] (1632) : GUARD, WATCH esp : a soldier standing guard at a point of passage (as a gate)

sentry box *n* [ca. 1728] : a shelter for a sentry on his post

sepal \sep'əl, 'sep-əl\ *n* [NL *sepala*, fr. *sepa-* (*Gk* *skēpē* covering) + *-al* (as in *petalum* petal); akin to Lith. *kuprē* head covering] (1821) : one of the modified leaves comprising a calyx — see FLOWER illustration

sepaloïd \-pəlōid\ *adj* (1830) : resembling or functioning as a sepal

sepaloous \sep-ə-lōs\ *adj* comb form [sepal]: having (such or so many) sepals (*gamosepalous*)

separa-ble \sep-ə-bəl\ *adj* [ME, fr. L *separabilis*, fr. *separare*] (14c) 1 : capable of being separated or dissociated 2 *obs.* 2 obs. : causing separation — *sep-a-ra-bil-i-ty* \sep-ə-bəl-ə-tē\ *n* — *sep-a-ra-bil-ness* *n* — *sep-a-ra-bly* \-bli\ *adv*

separate \sep-ə-rāt\ *vb* -ra-ted; -ra-ting [ME *separaten*, fr. L *separare* pp. of *separare*, fr. *se-* apart + *parare* to prepare, procure — more at SECEDE, PARE] *v* 1 *a* : to set or keep apart : DISCONNECT, SEVER *b* : to make a distinction between : DISCRIMINATE, DISTINGUISH (*~ religion from magic*) *c* : SORT (*~ mail*) *d* : to disperse in space or time : SCATTER (*widely separated* *homesteads*) 2 *archaic* : to set aside for a special purpose : CHOOSE, DEDICATE 3 : to part by a legal separation: *a* : to sever conjugal ties with *b* : to sever contractual relations with : DISCHARGE (*separated from the army*) 4 : to block off : SEGREGATE 5 *a* : to isolate from a mixture : EXTRACT (*~ cream from milk*) *b* : to divide into constituent parts *~ vi* 1 : to become divided or detached 2 *a* : to sever an association : WITHDRAW *b* : to cease to live together as man and wife 3 : to go in different directions 4 : to become isolated from a mixture

syn SEPARATE, PART, DIVIDE, SEVER, SUNDER, DIVORCE mean to become or cause to become disunited or disjointed. SEPARATE may imply any of several causes such as dispersion, removal of one from others, or presence of an intervening thing; PART implies the separating of things or persons in close union or association; DIVIDE implies separating into pieces or sections by cutting or breaking; SEVER implies violence esp. in the removal of a part or member; SUNDER suggests violent rending or wrenching apart; DIVORCE implies separating two things that commonly interact and belong together.

separa-tor \sep-ə-tōr\ *adj* (1600) 1 *a* *archaic* : SOLITARY, SECLUDED *b* : IMMATERIAL, DISEMBODIED *c* : set or kept apart : DETACHED 2 *a* : not shared with another : INDIVIDUAL (*~ rooms*) *b* often *cap* : estranged from a parent body (*~ churches*) 3 *a* : existing by itself : AUTONOMOUS *b* : dissimilar in nature or identity *syn* see DISTINCT — *sep-a-rate-ly* \-(ə-)rət-ə, 'sep-ərət-ə\ *adv* — *sep-a-rate-ness* \-(ə-)rət-nəs\ *n*

separa-tor \sep-ə-tōr\ *n* (1892) 1 : OFFPRINT 2 : an article of dress designed to be worn interchangeably with others to form various costume combinations — *usu.* used in pl.

separa-tion \sep-ə-'rā-shən\ *n* (15c) 1 : the act or process of separating : the state of being separated 2 *a* : a point, line, or means of division *b* : an intervening space : GAP 3 *a* : cessation of cohabitation between husband and wife by mutual agreement or judicial decree *b* : termination of a contractual relationship (as employment or military service)

separa-tion-ist \-shə-nə-'nist\ *n* (1882) : SEPARATIST

separa-tism \sep-ə-'rā-tiz-əm\ *n* (1628) : a belief in, movement for, or state of separation (as schism, secession, or segregation)

separa-tist \sep-ə-'rā-tist, 'sep-ə-rāt-əst\ *n* (1608) : one that favors separation: *a* *cap* : one of a group of 16th and 17th century English Protestants preferring to separate from rather than to reform the Church of England *b* : an advocate of independence or autonomy for a part of a political unit (as a nation) *c* : an advocate of racial or cultural separation — *separatist* *adj* — *sep-a-ra-tis-tic* \sep-ə-'rā-tis-tik\ *adj*

separa-tive \sep-ə-'rāt-iv, 'sep-ə-'rāt-əv\ *adj* (1592) : tending toward, causing, or expressing separation

separa-tor \sep-ə-'rāt-ər\ *n* (1607) : one that separates; esp : a device for separating liquids of different specific gravities (as cream from milk) or liquids from solids

Se-phar-di \sa-'fār-dē\ *n*, pl Se-phar-dim \-'fār-dəm\ [LHeb *séphārādī*, fr. *séphārād* Spain, fr. Heb. region where Jews were once exiled (*Obad 1; 20*) (1851)] : a member of the occidental branch of European Jews settling in Spain and Portugal and later in Greece, the Levant, England, the Netherlands, and the Americas; also : one of their descendants — *Se-phar-dic* \-'fār-dik\ *adj*

se-pia \sep'ē-ə, 'sep-ē-ə\ *n* [L, cuttlefish, ink, fr. Gk *sepiā*; akin to Gk *sepein* to make putrid, *sepēs* rotten] (1821) 1 *a* : the inky secretion of a cuttlefish *b* : brown melanin-containing pigment from the ink of cuttlefishes 2 : a print or photograph of a brown color resembling sepiia 3 : a brownish gray to dark olive brown

se-pia adi (1827) 1 : made of or done in sepiia 2 : of the color sepiia

se-pi-olite \sep'ē-pē-ə-līt\ *n* [G *seplōsith*, fr. Gk *sepiōn* cuttlebone (fr. *sepiā*) + G. *lith-* *lite*] (1854) : MEERSCHAUM 1

se-poy \sep'-pōi\ *n* [Pg *sepāl*, fr. Hindi *sepāhī*, fr. Per., cavalryman] (1717) : a native of India employed as a soldier by a European power

se-pu-ku \sep'-pū-kū\ *n*, pl *sep-ku-s* \sep'-kū\ [Jp] (1904) : HARA-KIRI

se-psi \sep'-sās\ *n*, pl *sep-ses* \sep'-sēz\ [NL, fr. Gk *sepsis* decay, fr. *sepein* to make putrid] (1876) : a toxic condition resulting from the spread of bacteria or their products from a focus of infection; esp : SEPSIS

septi-tem-ber \sep-tēm'-bər\ *n* [prob. alter. of *septi*] (1517) : a branch of a family; esp : CLAN

sep-tate \sep-tāt\ *adj* (1839) : of or relating to a septum

sep-tate \sep'-tāt\ *adj* (1846) : divided by or having a septum

Septem-ber \sep-tēm'-bər, sop'\ *n* [ME *Septembre*, fr. OF & OE, both fr. L *September* (seventh month), fr. *septem* seven — more at SEVEN] (bef. 12c) : the 9th month of the Gregorian calendar

sep-te-mi-nal-us \sep-tē'-mə-nəl-əs, -nər-\, n, pl *sep-tē-mi-nal-i-ty* \-tēl-ə-tē\ *n* [L, fr. *septem* of seven, fr. *septen* seven, fr. *septem* seven] (1819) : a verse consisting of seven feet esp. in Latin prosody

sept-en-de-cil·lion (ə-sep'-ten-di'-sil-yən) *n.* often attrib [L *septendecim* seventeen (fr. *septem* seven + *decem* ten) + *-illion* (as in *million*) — more at *TEN*] (ca. 1938) — see *NUMBER table*

sept-en-ni-al \sep'-en-nē-əl\ *adj* [LL *septenarius* period of seven years, fr. L *septem* + *-ennum* (as in *biennium*)] (1640) 1 : occurring or being done every seven years 2 : consisting of or lasting for seven years — *sep-tin-ni-al* \ə-lē'əl\ *adj*

sept-en-tri-on \sep'-en-trē-ən, -ēn, -trē-ən\ *n* [ME, fr. MF, fr. L *septentrionalis*, sing. of *septentriones* the seven stars of Ursa Major or Ursa Minor, lit. the seven plow oxen, fr. *septem* seven + *trio* plow ox] (14c) : the northern regions : **NORTH**

sept-en-tri-onal \-trē-ən-əl\ *adj* (14c) : NORTHERN

sep-tec \sep'-tēk\ *n* [G *septēs*, fr. L *septem*] (1837) 1 : a musical composition for seven instruments or voices 2 : a group or set of seven: esp. : the performers of a septet

sep-tic \sep'-tik\ *adj* [NL *septicus*, fr. Gk *septikos*, fr. *sepein* to make putrid — more at *SEPIA*] (1605) 1 : PUTREFACTIVE 2 : relating to, involving, or characteristic of sepsis

sep-tic-emia \sep'-tik-ē-mē-ə\ *n* [NL, fr. L *septicus* + NL *-emia*] (1866) : invasion of the bloodstream by virulent microorganisms from a local seat of infection accompanied esp. by chills, fever, and prostration — called also blood poisoning; compare *SEPSIS* — *sep-tice-mic* \'-sē-mik\ *adj*

sep-ti-cl-dal \sep'-tē-kīl-dāl\ *adj* [NL *septum* + L *-cidere* to cut, fr. *caedere* — more at *CONCISE*] (1819) : dehiscent longitudinally at or along a septum (as a fruit)

septic sore throat *n* (1924) : an inflammatory sore throat caused by hemolytic streptococci and marked by fever, prostration, and toxemia

septic tank, *n* (ca. 1902) : a tank in which the solid matter of continuously flowing sewage is disintegrated by bacteria

sep-ti-ri-gal \sep'-tē-rē-gāl\ *adj* [NL *septum* + L *frangere* to break — more at *BREAK*] (1819) : dehiscent by breaking away from the dissepiments (as a pod)

sep-ti-lion \sep'-tē-yən\ *n.* often attrib [F, fr. L *septem* + F *-illion* (as in *million*) — more at *SEVEN*] (1690) — see *NUMBER table*

sep-tu-a-gen-i-an \sep'-tē-yə-jēn-ē-ən\ *n* [L *septuagenarius* seventy years old, fr. L *septuageni* seventy each, fr. *septuaginta*] (1805) : a person whose age is in the seventies — *septuagenarian* *adj*

Sep-tu-a-ge-si-ma \sep'-tē-wā'-jē-sē-mə\ *n* [ME, fr. LL, fr. L, stem of *septuagesimus* seventieth, fr. *septuaginta* seventy; fr. its being approximately seventy days before Easter] (14c) : the third Sunday before Lent

Sep-tu-a-gint \sep'-tē-yē-jēnt, 'sep-tə-wā-jēnt\ *n* [LL *Septuaginta*, fr. L *septuaginta*, irreg, fr. *septem* seven + *-ginta* (akin to L *viginti* twenty); the approximate number of its translators — more at *SEVEN, VIGESIMAL*] (1633) : a pre-Christian Greek version of the Jewish Scriptures redacted by Jewish scholars and adopted by Greek-speaking Christians — *Sep-tu-a-gintal* \(\sep'-tē-yē-jēnt'-əl, sep-tə-wā-jēnt'-əl\ *adj*

sep-tum \sep'-təm\ *n.* pl *sep-ta* \-tə\ [NL, fr. L *septum* enclosure, fence, wall, fr. *sepein* to fence in, fr. *sepeis* fence, hedge; akin to Gk *haimas* stone wall] (1726) : a dividing wall or membrane esp. between bodily spaces or masses of soft tissue — compare *DISSEPTIMENT*

'sep-ul-cher or sep-ul-chre \sep'-əl-kər\ *n* [ME *sepulcre*, fr. OF, fr. L *sepulcrum*, *sepulchrum*, fr. *seperile* to bury; akin to Gk *hepein* to care for, Skt *sapati* he serves] (13c) 1 : a place of burial : **TOMB** 2 : a receptacle for religious relics esp. in an altar

<sup>2</sup>sepulcher or sepulchre \-chered or -chred; -chering or -chring\ \'-kərēd'\ (1591) 1 *archaic* : to place in or as if in a sepulcher : **BURY** 2 *archaic* : to serve as a sepulcher for

sep-ul-chral \'-pəl-kral\ *adj* (1615) 1 : MORTUARY 2 : suited to or suggestive of a sepulcher : **FUNERAL** — *sep-ul-chral-ly* \'-krəl-ē\ *adv*

sep-ut-ture \sep'-əl-chūrə\ *n* [ME, fr. L *septitura*, fr. *septus*, pp. of *seperile*] (13c) 1 : BURIAL 2 : *SEPULCHER*

seq-u-a-cious \sē'-kwā-shəs\ *adj* [L *sequac-*, *sequax* inclined to follow, fr. *sequi*] (1643) 1 *archaic* : SUBSERVIENT, TRACTABLE 2 : intellectually servile — *seq-u-a-cious-ly* *adv* — *seq-uac-ity* \'-kwās-ətē\ *n*

seq-uel \sē'-kwəl\ also \-kwəl\ *n* [ME, fr. MF *sequelle*, fr. L *sequela*, fr. *sequi* to follow — more at *SUE*] (15c) 1 : CONSEQUENCE, RESULT 2 : a subsequent development *a* : the next installment (as of a speech or story); esp : a literary or cinematic work continuing the course of a story begun in a preceding one

seq-uel-a \sē'-kwēl-ə\ *n*, pl *seq-uel-ae* \'-kwēl-ē\ [NL, fr. L, *sequela*] (1793) 1 : an aftereffect of disease or injury 2 : a secondary result

'seq-ue-nc-e \sē'-kwən-sē\ *n* [ME, fr. MF *sequencia*, fr. L *sequēns*, lit. act of following, fr. L *sequēns*, *sequens*, pp. of *sequi*] (14c) 1 : a hymn in irregular meter between the gradual and Gospel in masses for special occasions (as Easter) 2 : a continuous or connected series: as *a* : an extended series of poems united by a single theme (as sonnet ~) *b* : three or more playing cards usu. of the same suit in consecutive order of rank *c* : a succession of repetitions of a melodic phrase or harmonic pattern each in a new position *d* : a set of elements, ordered as are the natural numbers *e* (1) : a succession of related shots or scenes developing a single subject or phase of a film story (2) : EPISODE 3 *a* : order of succession *b* : an arrangement of the tenses of successive verbs in a sentence designed to express a coherent relationship esp. between main and subordinate parts 4 : **CONSEQUENCE, RESULT** *b* : a subsequent development 5 : continuity of progression

seq-ue-nced; seq-ue-ncing (1941) 1 : to arrange in a sequence 2 : to determine the sequence of chemical constituents (as amino-acid residues) in (sequenced) biological macromolecules

seq-ue-nce \sē'-kwēns\ *n* (1949) : any of various devices for arranging (as informational items or the events in the launching of a rocket) into or separating (as amino acids from protein) in a sequence

& Co. 1

,.CSV<=t@

## 1074 sequency • series-wound

se-quent-*cy* \sé-kwént\ *n* [LL *sequentialia*] (1818) : SEQUENCE 3a. 5  
 se-quent \sé-kwént\ *adj* [L *sequent*, *sequens*, *pp.*] (1601) 1 : CONSECUTIVE, SUCCEEDING 2 : CONSEQUENT, RESULTANT  
 se-quent-*ial* \sé-kwént-é\ *adj* (1854) 1 : of, relating to, or arranged in a sequence : SERIAL (< file systems>) 2 : following in sequence 3 : relating to or based on a method of testing a statistical hypothesis that involves examination of a sequence of samples for each of which the decision is made to accept or reject the hypothesis or to continue sampling — se-quent-*ial*-ly \k'wéntch-(s)-lē\ *adv*  
 se-ques-tor \sé-kwéz-tor\ *vt* -tered; -ter-ing \sé-kwéz-tor\ [ME *sequestren*, fr. MF *sequestrer*, fr. LL *sequestrare* to surrender for safekeeping, set apart, fr. L *sequester* agent, depositary, bailee; akin to L *sequi* to follow] (14c) 1 a : to set apart : SEGREGATE b : SECLUDE, WITHDRAW 2 a : to seize esp. by a writ of sequestration b : to place (property) in custody esp. in sequestration 3 : to hold (as a metallic ion) in solution usu. by inclusion in an appropriate coordination complex  
 sequester *n*, *obs* (1604) : SEPARATION, ISOLATION  
 se-ques-tre<sup>ate</sup> \sé-kwéz-trät, sék-, sé-kwéz-, w. -trated; -trating [LL *sequestrare*, pp. of *sequestrare*] (1513) : SEQUESTER  
 se-ques-tration \sé-kwéz-trä-shən, sék-, sé-kwéz-\ *n* (15c) 1 : the act of sequestering : the state of being sequestered 2 a : a legal writ authorizing a sheriff or commissioner to take into custody the property of defendant who is in contempt until he complies with the orders of a court b : a deposit whereby a neutral depositary agrees to hold property in litigation and to restore it to the party to whom it is adjudged to belong  
 se-ques-trum \sé-kwéz-trüm\ *n*, *pl* -trums also -tra \-trü\ [NL, fr. L, legal sequestration; akin to L *sequester* bailee] (1831) : a fragment of dead bone detached from adjoining sound bone  
 se-quin \sé-kwéen\ *n* [F, fr. It *zecchino*, fr. *zecca* mint, fr. Ar *sikkah* die, coin] (1582) 1 : an old gold coin of Italy and Turkey 2 : a small plate of shining metal or plastic used for ornamentation esp. on clothing  
 se-quined or se-quinned \k'wénd\ *adj* (1582) : ornamented with or as if with sequins  
 se-qui-tur \sé-kwé-tor, -wó-, -tú(s)r\ *n* [L, it follows, 3d pers. sing. pres. indic. of *sequi* to follow — more at SUE] (1836) : the conclusion of an inference : CONSEQUENCE  
 se-quoia \sé-kwó-y\ *n* [NL, genus name, fr. *Sequoia* (George Guess)] (ca. 1866) : either of two huge coniferous California trees of the pine family that reach a height of over 300 feet: a : BIG TREE b : REDWOOD 3a  
 seral *pl* of SERUM  
 serac \sé-rak, sé-\ *n* [F *sérac*, lit., a kind of white cheese, fr. ML *seracum* whey, fr. L *serum* whey — more at SERUM] (1800) : a pinnacle, sharp ridge, or block of ice among the crevasses of a glacier  
 ser-aglio \sé-rá-lyö, -fäl-, -fäl-\ *n*, *pl* -glios [It *seraglio* enclosure, seraglio, partly fr. ML *serraculum* enclosure, bar of a door, bolt, fr. LL *serare* to bolt; partly fr. Turk *saray* palace — more at SAR] (1588) 1 : Harem 2 : a palace of a sultan  
 serai \sé-ré\ *n* [Turk & Per; Turk *saray* mansion, palace, fr. Per *sard* mansion, inn] (1609) 1 : CARAVANSARY 2 : SERAGLIO 2  
 serial \sé-ré\ *adj* (1858) : of, relating to, or constituting an ecological series  
 se-ra-pe \sé-rá-pé, -rap-\ *n* [MexSp *sarape*] (1834) : a colorful woolen shawl worn over the shoulders esp. by Mexican men  
 ser-aph \sé-réf\ *n*, *pl* ser-a-phim \-fim\ or seraphs [back-formation fr. *seraphim*] (1667) : SERAPHIM 2  
 ser-a-phim \sé-réf-him\ *n*, *pl* [LL *seraphim*, pl. seraphs, fr. Heb *śérāphîm*] (bef. 12c) 1 : an order of angels — see CELESTIAL HIERARCHY 2 sing. pl seraphim : one of the 6-winged angels standing in the presence of God — see — seraph \sé-ráf-ik\ *adj* — seraph-i-cally \-i-ki-(s)-lē\ *adv*  
 Ser-apis \sé-rá-pé\ *n* [L, fr. Gk *Sarapis*] : an Egyptian god combining attributes of Osiris and Apis and having a widespread cult throughout Greece and Rome  
 Serb \sérb\ *n* [Serb *Srb*] (1860) 1 : a native or inhabitant of Serbia 2 : SERBIAN 2 — Serb *adj*  
 Ser-bian \sérb-é-un\ *n* (1862) 1 : SERB 2 a : the Serbo-Croatian language as spoken in Serbia b : a literary form of Serbo-Croatian using the Cyrillic alphabet — Serbian *adj*  
 Ser-bo-Cro-a-tian \sérb-ó-kro-té-un\ *n* (1883) 1 : the Slavic language of the Serbs and Croats consisting of Serbian written in the Cyrillic alphabet and Croatian written in the Roman alphabet 2 : one whose native language is Serbo-Croatian — Serbo-Croatian *adj*  
 ser-e \sé-ré\ *adj* [ME, fr. OE *sér* dry; akin to OHG *sörēn* to wither, Gk *hauros* dry] (bef. 12c) 1 : being dried and withered 2 archaic : THREADBARE  
 ser-e *n* [L *series* series] (1939) : a series of ecological communities formed in ecological succession  
 ser-e-nade \sé-ré-nád\ *n* [F *sérénade*, fr. It *serenata*, fr. *sereno* clear, calm (of weather), fr. L *serenus* serene] (1649) 1 a : a complimentary vocal or instrumental performance; esp. : one given outdoors at night for a woman b : a work so performed 2 : an instrumental composition in several movements, written for a small ensemble, and midway between the suite and the symphony in style  
 serenade *vb* -nad-ed; -nad-ing *v* (1672) : to perform a serenade in honor of ~ vi; to play a serenade — ser-e-nader<sup>n</sup>  
 ser-e-na-ta \sé-ré-ná-tä\ *n* [It, *serenata*] (ca. 1724) : an 18th century secular cantata of a dramatic character usu. composed in honor of an individual or event  
 ser-e-nip-tous \sé-ré-nip-tüs\ *adj* (1943) : obtained or characterized by serendipity (< discoveries>) — ser-e-nip-tous-ly *adv*  
 ser-e-nip-ti-ty \-nip-té\ *n* [fr. its possession by the heroes of the Persian fairy tale *The Three Princes of Serendip*] (1754) : the faculty of finding valuable or agreeable things not sought for  
 ser-e-rene \sé-ré-rén\ *adj* [L *serenus*; akin to OHG *serawēn* to become dry, Gk *xéros* dry] (1503) 1 : AUGUST — used as part of a title (*His Serene Highness*) 2 : marked by or suggestive of utter calm and unruffled repose or quietude (< smile>) 3 a : clear and free of storms or unpleasant change (< skies>) b : shining bright and steady (the moon, ~ in glory —Alexander Pope) syn see CALM — se-rene-ly *adv* — se-rene-ness \sé-rén-nös\ *n*

•serene *n* (1644) 1 : a serene condition or expanse (as of sky, sea, or light) 2 : SERENITY, TRANQUILLITY  
 se-re-ni-ty \sé-ré-né-té\ *n* [ME, fr. MF *serenité*, fr. L *serenitatis*, *serenita* fr. *serenus* serene] (15c) : the quality or state of being serene  
 serf \sérf\ *n* [F, fr. L *serfus* slave, servant, serf — more at SERVE] (161) : a member of a servile feudal class bound to the soil and subject to the will of his lord — serf-age \sérf-ij\ *n* [ME *serfdom*, -dom] *n* serge \sárg\ *n* [ME *serge*, fr. MF, fr. (assumed) VL *serica*, fr. L *seric* fem. of *sericus* silken — more at SERICEOUS] (14c) : a durable twill fabric having a smooth clear face and a pronounced diagonal rib on the front and the back  
 ser-geantcy \sárg-jént-sé\ *n* (1670) : the function, office, or rank of sergeant  
 sergeant \sárg-jént\ *n* [ME, servant, attendant, sergeant, fr. MF *serger*, *serjant*, fr. L *servient*, *serviens*, *pp.* of *servire* to serve] (14c) 1 : SERGEANT AT ARMS 2 obs : an officer who enforces the judgments of court or the commands of one in authority 3 : a noncommissioned officer ranking in the army and marine corps above a corporal and below a staff sergeant and in the air force above an airman first class; senior airman and below a staff sergeant; broadly : NONCOMMISSIONED OFFICER 4 : an officer in a police force ranking in the U.S. just below captain or sometimes lieutenant and in England just below inspector sergeant at arms (14c) : an officer of an organization (as a legislative body or court of law) who preserves order and executes commands sergeant first class *n* (1948) : a noncommissioned officer in the army ranking above a staff sergeant and below a master sergeant sergeant fish *n* (ca. 1883) 1 : COBIA 2 : SNOOK 1  
 sergeant major *n*, *pl* sergeants major or sergeant majors (1802) 1 : noncommissioned officer in the army, air force, or marine corps serving as chief administrative assistant in a headquarters 2 : a noncommissioned officer in the marine corps ranking above first sergeant 3 : bluish green to yellow percoid fish (*Abudefduf saxatilis*) with black vertical stripes on the sides that is widely distributed in the western tropical Atlantic ocean  
 sergeant major of the army (1966) : the ranking noncommissioned officer of the army serving as adviser to the chief of staff sergeant major of the marine corps (ca. 1971) : the ranking noncommissioned officer of the marine corps serving as adviser to the commanding sergeant major of the army (1966) : the ranking noncommissioned officer of the army serving as adviser to the chief of staff sergeant major of the marine corps (ca. 1971) : the ranking noncommissioned officer of the marine corps serving as adviser to the commanding sergeantcy \sárg-jént-é\ *n*, *pl* -geant-ies [ME *sergeantie*, fr. MF *sergent*, fr. *sergent sergeant*] (15c) : any of numerous feudal services of a personal nature by which an estate is held of the king or other lord distinct from military tenure and from socage tenure  
 serg-ing \sárg-jéng\ *n* [serge] (ca. 1909) : the process of overcasting the raw edges of a piece of fabric (as a carpet) to prevent raveling  
 ser-i-al \sir-é-äl\ *adj* (1841) 1 : of, relating to, consisting of, or arranged in a series, rank, or row (< order>) 2 : appearing in successive parts or numbers (< a story>) 3 : belonging to a series maturing periodically rather than on a single date (< bonds>) 4 : of, relating to, or being music based on a series of tones in an arbitrary but fixed pattern without regard for traditional tonality (< technique>) — ser-i-al-ly \-äl-é\ *adv*  
 serial *n* (1846) 1 a : a work appearing (as in a magazine or on television) in parts at intervals b : one part of a serial work : INSTALLMENT 2 : a publication (as a newspaper or journal) issued as one of a conveniently numbered and indefinitely continued series  
 ser-i-al-ism \sir-é-äl-iz-ém\ *n* (1963) : serial music; also : the theory and practice of composing serial music  
 ser-i-al-ist \sir-é-äl-ist\ *n* (1846) 1 : a writer of serials 2 : a composer of serial music  
 ser-i-al-ize \sir-é-äl-iz\ *vt* -ized, -izing (1892) : to arrange or publish in series — ser-i-al-ization \sir-é-äl-iz-ä-shän\ *n*  
 serial number *n* (1896) : a number indicating place in a series and used as a means of identification  
 ser-i-ate \sir-é-ät, -ät\ *adj* [(assumed) NL *seriatus*, fr. L *series*] (1844) 1 : arranged in a series or succession — ser-i-ate-ly *adv*  
 ser-i-ate \sir-é-ät\ *vt* -at-ed; -at-ing (1872) : to arrange in a series  
 ser-i-ati-on \sir-é-ät-é-on, -ät-, -ä-shän\ *n* [ML, fr. L *series*] (1680) : in a series  
 seriatim *adj* (1871) : following seriatim  
 ser-i-ceous \sir-é-çé-üs\ *adj* [LL *sericeus* silken, fr. L *sericum* silk garment, silk, fr. neut. of *sericus* silken, fr. Gk *serikos*, fr. *Serēs*, an eastern Asian people producing silk in ancient times] (ca. 1777) : finely pubescent (< leaf>)  
 ser-i-cin \sir-é-çé-n\ *n* [ISV, fr. L *sericum* silk] (ca. 1868) : a gelatinous protein that cements the two fibroin filaments in a silk fiber  
 ser-i-cul-ture \sir-é-çé-lü-tü-r\ *n* [L *sericum*, silk + E culture] (1853) : the production of raw silk by raising silkworms — ser-i-cul-tur-ly \-lü-tü-ré\ *adv* — ser-i-cul-tur-ist \-lü-tü-ré\ *n*  
 ser-ies \sir-éz\ *n*, *pl* series often attrib [L, fr. *serere* to join, link together; akin to L *sor*, sor lot, Gk *eirin* to string together, *horm* chain, necklace] (1611) 1 a : a number of things or events of the same class coming one after another in spatial or temporal succession (< a concert>) 2 b : a set regularly presented television programs each of which is complete itself 2 : the indicated sum of a usu. infinite sequence of numbers a : the coins or currency of a particular country and period b : group of postage stamps in different denominations 4 : a successive group of volumes or issues published with related subjects or authors, similar format and price, or continuous numbering 5 : a division of formations that is smaller than a system and comprises rocks deposited during an epoch 6 : a group of chemical compounds related in composition and structure 7 : an arrangement of the parts of or elements in an electric circuit whereby the whole current passes through each part or element without branching 8 : a set of vowels connected ablativ (as i, u, a in ring, rang, rung) 9 a : a number of games (as baseball) played usu. on consecutive days between two teams (in tot for a 3-game) ~ b : WORLD SERIES 10 : a group of successive coordinate sentence elements joined together (an a, b, and c ~) 11 : SC. SERIES 12 : three consecutive games in bowling — in series : in a series arrangement  
 series winding *n* (ca. 1909) : a winding in which the armature coil in the field-magnet coil are in series with the external circuit — se-rie-wound \sir-éz-waud\ *adj*

## 1132 special • spectrofluorometric

eminence or preference; **SPECIFIC** implies a quality or character distinguishing a kind or a species; **PARTICULAR** stresses the distinctness of something as an individual; **INDIVIDUAL** implies unequivocal reference to one of a class or group.

**special** (ca. 1909) 1: something (as a television program) that is not part of a regular series 2: one that is used for a special service or occasion (caught the commuter ~ to work)

**special assessment** n (1875): a specific tax levied on private property to meet the cost of public improvements that enhance the value of the property

**special delivery** n (1886): expedited messenger delivery of mail matter for an extra fee

**special district** n (1950): a political subdivision of a state established to provide a single public service (as water supply or sanitation) within a specific geographical area

**special drawing rights** n (1967): a means of exchange used by governments to settle their international indebtedness

**special effects** n pl (1944): visual or sound effects introduced into a motion picture or a taped television production during laboratory processing

**Special Forces** n pl (1962): a branch of the army composed of men specially trained in guerrilla warfare

**special handling** n (1928): the handling of parcel-post or fourth-class mail as first-class but not as special-delivery matter for an extra postal fee

**special interest** n (1910): a person or group seeking to influence legislative or government policy to further often narrowly defined interests; esp: **LOBBY**

**special-ism** \spe-shəl-izm\ n (1856) 1: specialization in an occupation or branch of learning 2: a field of specialization; **SPECIALITY**

**special-ist** \spe-shəl-ist\ n (1856) 1: one who devotes himself to a special occupation or branch of learning 2: any of four enlisted ranks in the army corresponding to the grades of corporal through sergeant first class — **specialist** or **specia-list** \spe-shəl-ist\ adj

**special-ity** \spe-shəl-ə-tē\ n, pl -ties (15c) 1: a special mark or quality 2: a special object or class of objects 3 a: a special aptitude or skill b: a particular occupation or branch of learning

**special-iza-tion** \spe-shəl-ə-zā-shən\ n (1843) 1: a making or becoming specialized 2 a: structural adaptation of a body part to a particular function or of an organism for life in a particular environment b: a body part or an organism adapted by specialization

**special-ize** \spe-shəl-iz\ vb -ized; -izing vt (1613) 1: to make particular mention of; **PARTICULARIZE** 2: to apply or direct to a specific end or use **(specialized his study)** ~ vi 1: to concentrate one's efforts in a special activity or field 2: to undergo specialization; esp: to change adaptively (the sloth became highly **specialized** in the course of evolution)

**specialized** adj (1853) 1: designed or fitted for one particular purpose or occupation (~ personnel) 2: characterized by or exhibiting biological specialization; esp: highly differentiated esp. in a particular direction or for a particular end

**special jury** n (1730): a jury chosen by the court on request from a list of better educated or presumably more intelligent prospective jurors for a case involving complicated issues of fact or serious felonies — called also *blue-ribbon jury*

**special pleading** n (1684) 1: the allegation of special or new matter to offset the effect of matter pleaded by the opposite side and admitted, as distinguished from a direct denial of the matter pleaded 2: misleading argument that presents one point or phase as if it covered the entire question at issue

**special theory of relativity** (1924): **RELATIVITY** 3a

**special-ty** \spe-shəl-tē\ n, pl -ties [ME **speciate**, fr. MF **especialité**, fr. LL **specialitat**, **specialitas**, fr. L **specialis** special] (14c) 1: a distinctive mark or quality 2 a: a special object or class of objects: as (1): a legal agreement embodied in a sealed instrument (2): a product of a special kind or of special excellence (fried chicken was father's ~) b: the state of being special, distinctive, or peculiar 3: something in which one specializes

**specia-tive** \spe-shə-tiv\ n (ca. 1900): the process of biological species formation — **speciate** \spe-shə-tāt\ vt — **specia-tional** \spe-shə-tōnāl, shənāl\ adj

**specie** \spe-shē, -sē\ [fr. L. in kind] (1617): money in coin — in specie: in the same or like form or kind (ready to return insult in specie) also: in coin

**specie** n [back-formation fr. **species** (taken as a pl.)] **substand** (1711) : **SPECIES**

**specie** \spe-shē, -sē\ n, pl **species** [L. **specie**, appearance, kind, species — more at **SPY**] (1551) 1 a: a class of individuals having common attributes and designated by a common name; **specif**: a logical division of a genus or more comprehensive class b: **KIND**, **SORT** c: the human race: human beings — often used with the (survival of the ~ in the nuclear age) d (1): a category of biological classification ranking immediately below the genus or subgenus, comprising related organisms or populations potentially capable of interbreeding, and being designated by a binomial that consists of the name of a genus followed by a Latin or Latinized uncapitalized noun or adjective agreeing grammatically with the genus name (2): an individual or kind belonging to a biological species e: a particular kind of atomic nucleus, atom, molecule, or ion 2: the consecrated eucharistic elements of the Roman Catholic or Eastern Orthodox Eucharist 3 a: a mental image; also: a sensible object b: an object of thought correlative with a natural object

**species** adj (1899): belonging to a biological species as distinguished from a horticultural variety (~ rose)

**specie-ism** \spe-shē, -izm, -sē\ n [**species** + **-ism** (as in **racism**)] (1973): prejudice or discrimination based on species; esp: discrimination against animals

**specif-ic** \spe-fik\ adj [LL **specificus**, fr. L **species**] (1631) 1 a: constituting or falling into a specifiable category b: sharing or being those properties of something that allow it to be referred to a particular category 2 a: restricted to a particular individual, situation, relation, or effect (a disease ~ to horses) b: exerting a distinctive influence (as on a body part or a disease) (~ antibodies) 3: free from ambiguity: **ACCURATE** (a ~ statement of faith) 4: of, relating

to, or constituting a species and esp. a biologic species 5 a: being any of various arbitrary physical constants and esp. one relating a quantitative attribute to unit mass, volume, or area b: imposed at a fixed rate per unit (as of weight or count) (~ import duties) — compare **AD VALOREM** syn see **SPECIAL EXPLICIT** — **specif-i-cal-ly** \spe-fik-ə-lik\ adv

**specific** (1661) 1 a: something peculiarly adapted to a purpose or use b: a drug or remedy having a specific mitigating effect on a disease 2 a: a characteristic quality or trait b: **DETAILS**, **PARTICULARS** — usu. used in pl. (haggling over the legal and financial ~s of independence — **Time**) c pl: **SPECIFICATION** 2a

**speci-fi-ca-tion** \spe-si-fi-kā-shən\ n (1615) 1: the act or process of specifying 2 a: a detailed precise presentation of something or of a plan or proposal for something — usu. used in pl. b: a statement of legal particulars (as of charges or of contract terms); also: a single item of such statement c: a written description of an invention for which a patent is sought

**specific epithet** (1947): the Latin or Latinized noun or adjective that follows the genus name in a taxonomic binomial

**specific gravity** n (1666): the ratio of the density of a substance to the density of some substance (as pure water or hydrogen) taken as a standard when both densities are obtained by weighing in air

**specific heat** n (1832) 1: the ratio of the quantity of heat required to raise the temperature of a body one degree to that required to raise the temperature of an equal mass of water one degree 2: the heat in calories required to raise the temperature of one gram of a substance one degree centigrade

**specific impulse** n (1947): the thrust produced per unit rate of consumption of the propellant that is usu. expressed in pounds of thrust per pound of propellant used per second and that is a measure of the efficiency of a rocket engine

**speci-fic-ity** \spe-si-fik-ə-tē\ n (1876): the quality or condition of being specific: as a: the condition of being peculiar to a particular individual or group of organisms (host ~ of a parasite) b: the condition of participating in or catalyzing only one or a few chemical reactions (the ~ of an enzyme)

**specific performance** n (1873) 1: the performance of a legal contract strictly or substantially according to its terms 2: an equitable remedy enjoining specific performance

**speci-fy** \spe-si-fi\ vt -fied; -fy-ing [ME **specien**, fr. MF **specifier**, fr. LL **specificare**, fr. **specificus**] (14c) 1: to name or state explicitly or in detail 2: to include as an item in a specification — **speci-fi-able** \spe-si-fə-bəl\ adj — **speci-fier** \spe-si-fēr\ n

**speci-men** \spe-si-mən\ n [L. fr. **specere** to look at, look — more at **SPY**] (1610) 1: an item or part typical of a group or whole 2 a: something that obviously belongs to a particular category but is noticed by reason of an individual distinguishing characteristic b: PERSON, INDIVIDUAL (he's a tough ~) syn see **INSTANCE**

**speci-os-ity** \spe-si-shē-ə-tē\ n (1608): the quality or state of being specious: **SPECIOUSNESS**

**specious** \spe-pē-shēs\ adj [ME, fr. L **speciosus** beautiful, plausible, fr. **species**] (15c) 1 obs: **SHOWY** 2: having deceptive attraction or allure 3: having a false look of truth or genuineness: **SOPHISTIC** — **specious-ly** \spe-pē-shē-ə-ly\ adj — **specious-ness** n

**spec'k** \spek\ n [ME **specke**, fr. OE **specca**] (bef. 12c) 1: a small discoloration or spot esp. from stain or decay 2: a very small amount 3: bit 3: something marked or marred with specks — **specked** \spek-t\ adj

**spec'k** vt (1580): to produce specks on or in

**spec'k-əle** \spek-əlē\ n [ME; akin to OE **specca**] (15c) : a little speck (as of color)

**spec'k'le** \spek-əlē; spec'k-əd\; spec'k-ling \spek-ə-ling\ (ca. 1570) 1: to mark with speckles 2: to be distributed in or on like speckles

**speckled perch** n (1888): **BLACK CRAPPIE**

**speckled trout** n (1805) 1: **BROOK TROUT** 2: **SPOTTED SEA TROUT**

**spec's** \speks\ n pl [contr. of **specacles**] (1807): **EYEGLASSES**

**spec'p** n pl [by contr.] (1942): **SPECIFICATIONS**

**spec-tac-le** \spek-tākəl also -tik-əl\ n [ME, fr. L **spectaculum**, fr. **spectare** to watch, fr. **spectus**, pp. of **specere** to look, look at — more at **SPY**] (14c) 1 a: something exhibited to view as unusual, notable, or entertaining; esp: an eye-catching or dramatic public display b: an object of curiosity or contempt (made a ~ of herself) 2 pl: **GLASSES** 3: something (as natural markings on an animal) suggesting a pair of glasses

**spec-tac-les** \spek-tākəl, -tik-əl\ adj (1607) 1: having or wearing spectacles 2: having markings suggesting a pair of spectacles (a ~ alligator)

**spec-tac-u-lar** \spek-tāk-yə-lər, spek-\ adj [L **spectaculum**] (1682) : of, relating to, or constituting a **spectacle**: **STRIKING**, **SENSATIONAL** (a ~ display of fireworks) — **spec-tac-u-lar-ly** \spek-tāk-yə-lē\ adv

**spec-tac-u-lar** n (1890): something that is spectacular

**spec-tate** \spek-tāt\ vt spec-tat-ed; spec-tat-ing [back-formation fr. **spectator**] (1709) 1: to be present as a spectator (at as a sports event)

**spec-ta-tor** \spek-tāt-ər, spek-\ n [L. fr. **spectus**, pp. of **specere** to watch] (1586): one who looks on or watches — **spectator** adj

**spec-ta-tor** \spek-tāt-ər\ n [F **spectre**, fr. L **spectrum** appearance, specter, fr. **specere** to look, look at — more at **SPY**] (1605) 1: a visible disembodied spirit: **GHOST** 2: something that haunts or perturbs the mind: **PHANTASM** (the ~ of hunger)

**spec-ti-no-my-cin** \spek-tē-nō-mē-sēn\ n [NL, fr. **spectabilis** + *-in* + *-o-* + *-mycin*] (ca. 1964): a white crystalline broad-spectrum antibiotic  $C_{14}H_{21}N_2O_5$  produced by a bacterium (*Streptomyces spectabilis*) that is used clinically esp. in the form of its hydrochloride to treat gonorrhea

**spec-tral** \spek-trəl\ adj (1815) 1: of, relating to, or suggesting a specter: **GHASTLY** 2: of, relating to, or made by a spectrum — **spec-tral-ly** \spek-trə-lik\ adv

**spectral line** n (1902): one of a series of linear images of the narrow slit of a spectrograph or similar instrument corresponding to a component of the spectrum of the radiation emitted by a particular source

**spectro-comb form** [NL **spectrum**]: **spectrum** (**spectroscope**)

**spec-tro-flu-o-rome-tor** \spek-tro-flū-ō-romē-tər, -ō-romē-tər\ also **spec-tro-flu-o-rom-e-ter** \spek-tro-flū-ō-romē-tər\ n [spectr- + fluorometer] (1962): a device for measuring and recording fluorescence spectra — **spec-tro-flu-o-ro-met-ric**

## CAD Systems for IC Design

MARVIN E. DANIEL AND CHARLES W. GWYN, SENIOR MEMBER, IEEE

**Abstract**—As integrated circuit (IC) complexities increase, many existing computer-aided design (CAD) methods must be replaced with an integrated design system to support very large scale integrated (VLSI) circuit and system design. The framework for a hierarchical CAD system is described. The system supports both functional and physical design from initial specification and system synthesis to simulation, mask layout, verification, and documentation. The system is being implemented in phases on a DECSYSTEM 20 computer network and will support evolutionary changes as new technologies are developed and design strategies defined.

### INTRODUCTION

COMPUTER-AIDED DESIGN (CAD) of integrated circuits (IC's) has had various interpretations as a function of time and definition source. These interpretations range from use of simple, interactive graphics and digitizing systems to individual programs used for circuit or logic simulation, mask layout, and data manipulation or reformatting. In many instances, the word "aided" is deemphasized to imply nearly automatic design. Within the context used in this paper, CAD refers to a collection of software tools to provide the designer with design assistance during each phase of the design. Although many decisions are made by the software during the design process, important decisions are the designer's responsibility. The computer aids or tools provide the designer with a rapid and orderly method for consolidating and evaluating design ideas and relieve the designer of numerous routine and mechanistic design steps.

### Background

A brief review of some of the techniques and terminology that evolved into today's CAD is instructive to viewing the collection of tools available today. CAD had its origins in the mid-to-late 1950's. With the advent of high-speed digital computers, some of the pioneering work of Kron [1], [2] was applied to the simultaneous solution of network equations. This formulation was used, in part, by computer codes such as NET-1 [3] (Network Analysis Program) and ECAP [4] (Electronic Circuit Analysis Program). From a physical point of view, solution of the network problem predicts the behavior of a system in terms of the element characteristics and interconnections. Viewed as a mathematical problem, the properties of a topological structure (linear graph) and a superimposed algebraic structure (interrelations of the nodes, branches, and meshes of the graph) are determined.

Manuscript received April 10, 1981; revised September 8, 1981. This work was supported by the U.S. Department of Energy.

The authors are with Sandia National Laboratories, Integrated Circuit Design, Dept. 2110, Albuquerque, NM 87185.

This early work of solving steady-state and transient network problems was the genesis of circuit simulation and was designated CAD. By the early 1970's, the growing need to simulate large circuits and thus obtain the detailed solution of a large number of partial differential equations forced the development of optimization methods and higher levels of abstraction to represent physical systems. Whereas very detailed models are used to simulate the behavior of individual transistors, more abstract representations are used for timing and logic simulation. A timing simulator uses only current-voltage tables for transistor models; capacitive loading, and circuit connectivity to determine the signal waveforms at each circuit node. Logic or gate-level simulation solves the equivalent Boolean equations with delay elements inserted between gates to account for signal timing.

The use of computer aids in the layout of IC masks essentially proceeded along two approaches: interactive graphic systems and automatic layout based on standard cells. Early interactive graphic systems provided a method for capturing the design by recording coordinate information by manually digitizing and editing data. Methods for superimposing mask layers, scaling, enlarging, contrasting, and reviewing the results were expanded to provide fast, sophisticated drawing commands for constructing, editing, and reproducing complex figures; performing dimensional tolerance checks; selective expand, move, and merge; symbolic input; pattern generation, etc.

Automatic layout methods have classically relied on a library of circuit components or cells in the form of mask geometries defining logic gates. Most software required cells with standard heights and varying width. The layout software places cells in rows, attempts to optimize the cell position in the row, and interconnects the cells in wiring channels between the rows. The automatic standard cell layout programs have evolved from simple linear cell placement in a single row, which was subsequently folded to fit a square area [5], to complex placement in two dimensions. The early standard cell layout aids supported the use of single entry (connections on one side of the cell) cells placed in the row in a back-to-back configuration. Power was distributed to the cells through a common connection on the backside of the cell. Newer standard cell layout programs support cells containing terminals on both sides of the cell. Instead of placing cells in a back-to-back configuration, each cell row contains a linear placement of the cells [6], [7] and is separated by wiring channels.

The early use of CAD for physical design verification consisted of performing simple design rule checks for width spacing violations on mask artwork files. Functional integrity was verified through circuit simulations.

## SUMMARY DANIEL AND GWYN: CAD SYSTEMS FOR IC DESIGN

*Initial Sandia Design Aids*

After the initial decision to establish a CAD capability for integrated circuits at Sandia, software was obtained from universities and private industry wherever possible to provide a basic capability. For example, the SPICE [8] circuit analysis code was obtained from the University of California at Berkeley, and the PR2D [6] standard cell layout program for metal gate cells was obtained from RCA. Since Sandia had previously developed a simple logic analysis capability, this work was accelerated to provide gate-level simulation. Software was developed to postprocess the mask layout data to pattern generator formats for mask generation and plot file information for the Xynetics flatbed plotter. A software package was purchased from Systems, Science, and Software, Inc., and installed on an existing interactive graphic system. In addition, translator subroutines were written to convert design information data formats to minimize the manual data translation and to allow the design information to be added only once in each system. The above process is oversimplified, since a substantial commitment of staff was required to: (1) understand the acquired software and debug and correct errors, (2) perform modifications to support the software on Control Data computers, (3) identify and develop required translator software, and (4) develop additional design aids. These problems and the subsequent software modifications required a large manpower investment, since most of the software was not documented, had evolved over many years with several authors, used nonstandard Fortran, and was unstructured.

*CAD System Requirements*

Although the initial design aids provided a valuable capability for simple metal gate CMOS custom IC design, many deficiencies were identified. These deficiencies coupled with the need to support new technologies with shrinking design rules (and thus rapidly increasing circuit complexities), new design geometries, and changing design objectives, required a new approach with respect to the development of aids for IC design. Several general objectives for new aids were identified. The aids must (1) be user oriented, (2) use modular software, (3) be evolutionary to meet changing design needs, and (4) be integrated into a complete design system rather than exist as an independent collection of disjoint tools.

Computer aids must support both functional and physical design. Functional design aids include synthesis, verification, simulation, and testing at architecture, system, logic, circuit, device, and process levels. Physical design aids support partitioning, layout, and topological analysis at all design levels. Functionality, testability, and physical design must be considered in parallel throughout the design process.

All CAD software must be as technology independent as possible and support various levels of designer sophistication from inexperienced first-time users to state-of-the-art system designers. To meet these goals, the interaction between individual programs, data base, and design engineer must be through a single, consistent interface. This interface should support monitoring the progress of a design, supply options at every stage in the design process, and assist in design documenta-

TABLE I

| Complexity                                      | Example                                                               |
|-------------------------------------------------|-----------------------------------------------------------------------|
| VLSI (~10 <sup>5</sup> devices)                 | Microcomputers, cryptographic circuits, ROMs, RAMs                    |
| LSI (~10 <sup>4</sup> devices)                  | Microprocessors, A/D & D/A converters, ADCs, FFT circuits, ROMs, RAMs |
| MSI (~10 <sup>3</sup> devices)                  | Address, Complex gates, multiplexers, ROMs, RAMs                      |
| AND, OR, NAND, NOR gates, buffers, memory cells |                                                                       |
| Primitive elements                              | Transistors, resistors, capacitors                                    |

tation and maintenance.

A system design language—or Hardware Description Language (HDL)—must be available for describing all levels of system behavior and structure. Organized in a hierarchical manner, the language should support functional and physical descriptions and the relationships among entities.

Synthesis aids must facilitate the addition of sufficient detail to generate a complete system description. Design verification software monitors internal consistency and completeness of system specifications. Final system specifications should be retained in a dynamic data base providing files in the proper format for input to each of the design aids and for documentation.

A complete CAD system satisfying the above requirements has been designed and implementation is in progress. The basic system description has been divided into three sections. The first section describes design flow and the concept of top-down design with bottom-up implementation. A hierarchical design approach is used with appropriate merging of levels to accomplish the design of VLSI systems. Requirements for specific computer aids are outlined in the second section. The final section describes the implementation philosophy, computer hardware, and present software development status.

*HIERARCHICAL DESIGN*

The CAD system supports a number of functions at each level in the design hierarchy. Design proceeds in a top-down sequence with bottom-up detailed implementation and addresses both functional and physical problems at each level.

Architecture, the top level of the design hierarchy, contains elements for a broad functional system description, requirements for interfacing units specifying performance and compatibility, and methods for partitioning the system into major functional blocks such as processors, memory, and I/O. The architectural specification can be expanded at the system level to generate a more detailed description consisting of register transfer level subsystem functions.

At the logic level, system functions are defined as interconnections of fundamental gates or modules. Logic modules can be further decomposed into circuit primitives (e.g., transistors, resistors, capacitors). Finally, in order to construct circuit elements and determine their behavior, the physical implementation and process technology may be considered.

To support a variety of technologies in a hierarchical design structure, a data base consisting of a library of elements of varying sophistication must be maintained. A distinct library must exist for each technology used. Typically, the hierarchi-





The flow diagram in Fig. 1 is subdivided and enlarged to show the individual design steps in Figs. 2-7. The first major step consists of developing system specifications and partitioning guidelines (Fig. 2). After developing general specifications, systems, architecture, algorithms, and major functions are defined. Each subsystem is partitioned into IC blocks which are synthesized and simulated at the system design level. This preliminary design is evaluated and modified if necessary by repeating the above steps.

The next major step in the design is implementation of each based on the system specification (Fig. 3). For a general electronic system, the first decision to be made is whether home or commercial circuits will be used. If a characterized commercial circuit is available in the library, the circuit is se-

lected. If the required commercial circuit is not in the library, the specifications must be obtained and compared with the system specification. If the system specifications are met, the commercial circuit can be used; if not, a custom circuit must be designed.

The first step in designing a custom IC is partitioning the IC into subcircuits. Each subcircuit is synthesized and optimized. Module descriptions for each subcircuit are developed and verified, and a preliminary layout using the estimated module sizes is performed. At this point, a decision can be made concerning the adequacy of the partitioning. If the preliminary layout does not conform to the size restrictions for the circuit or if during the circuit verification, signal-delay paths are longer than desired, the partitioning must be modified and the circuit design repeated.

If partitioning is acceptable, the subcircuit design step can be initiated (Fig. 4). For each subcircuit design, a decision must be made concerning the adequacy of modules in the library for implementing the design; new modules must be designed and characterized as required (Fig. 5).

During subcircuit implementation, each circuit can be simulated at various individual or combined simulation levels, the testability evaluated, and the artwork generated. After art-

6 IEEE TRANSACTIONS ON COMPUTER-AIDED DESIGN OF INTEGRATED CIRCUITS AND SYSTEMS, VOL. CAD-1, NO. 1, JANUARY 1982



work design, the simulation net list must be updated to include circuit parasitics associated with the specific layout. This simulation also provides information concerning circuit output drive and power required for subcircuit operation. If the simulation is within tolerance, static design verification is initiated; connectivity is traced; and the layout is checked for conformance to design rules. The layout and associated simulation characteristics are compared with the initial circuit specifications. Finally, test information is generated for the subcircuit.

After each subcircuit design has been completed and verified, the circuit design information is added to a design file in the data base. The next major step consists of completing the IC design by combining subcircuit design information (Fig. 6). The IC layout is assembled by placing and interconnecting subcircuit layouts. The simulation is updated to assure correct circuit operation, test specifications are generated, and a fault dictionary is developed for system diagnosis. Physical design verification, including global rule checks and connectivity checks, is performed, and the mask information for each IC is generated. Finally, design information for each IC is added to the system data base.

The last major step in the design sequence consists of completing the system design (Fig. 7). After selecting commercial circuits or designing custom IC's, layouts are performed for the system circuit boards. After the printed- or hybrid-circuit board layouts have been completed, the entire system is simu-

lated, using detailed design information for each circuit. The simulation determines the electrical characteristics of the system and provides a final functional design verification by comparing simulation results with initial design specifications. Test sequences for the individual IC's are combined to produce system tests at the printed-circuit board or hybrid-circuit level. During the final step, system design documentation is generated and archived. Generating system documentation consists of obtaining information from the design data base and consolidating it into the appropriate format. In addition to the mask plot files and test-sequence information, the documentation includes system performance information with tolerance specifications for acceptance of the final system. The complete CAD system for IC design will include a number of computer programs. These aids can be categorized as follows: design specification and partitioning, system and circuit synthesis, system partitioning, simulation at various levels, IC mask layout, design verification, testability evaluation, test sequence generation, data base, and design documentation.

#### SPECIFIC COMPUTER AIDS REQUIREMENTS

In addition to a number of specific computer programs for supporting a hierarchical design, an extensive data base and support software for monitoring the design flow and communication are required. Requirements for specific programs and interfaces are outlined below.

#### Design Executive

Currently, most design automation programs exist as independent entities with idiosyncratic user interfaces and incompatible I/O structures. A Design Executive can provide a single

DEF011955

JANUARY 19

## DANIEL AND GWYN: CAD SYSTEMS FOR IC DESIGN

consistent interface between a user and the complete set of computer aids available on the CAD system.

The Design Executive supports the complex CAD system structure by mediating interactions between the user and the system, the system and the data base, and the user and the data base. The executive system user interface supports comprehensive "HELP" capabilities, the HDL, and a logically integrated command language. Documentation describing the system and the CAD codes is maintained by the Design Executive in a hierarchical configuration. User access to this documentation structure is facilitated by the intelligent intervention of the Design Executive.

*HDL—Design Specification*

The structure and behavior of a digital system must be described in various ways at many levels to completely characterize a design. Existing "languages" such as ISP [9], DDL [10], SDF [11] and are usually associated with specific descriptions of architecture, system behavior, system structure, logical structure, circuit structure, logical behavior, or physical structure. These descriptions lack the generality required to support VLSI design, since most are applicable to one level of design and a particular design style and are not integrated into a complete design system.

Ultimately, a comprehensive HDL must be used to describe all levels of system behavior and structure; including normal circuit operation and fault electrical operation, logical and functional behavior, as well as physical structure. Organized in a hierarchical manner, the HDL should allow description of functional and physical specifications, entities and relationships among entities.

*Functional Synthesis and Functional Verification*

Functional synthesis begins at the architecture level with a description of the overall behavior of a large system and interface with the environment. As synthesis proceeds, more structural detail is added at system, logic, and circuit levels in the form of interconnection structures. Concurrently, behavioral specifications are developed at each level of the design in with the hierarchy. During synthesis, the actual behavior of the system must be included and forced to match the specifications. To effect the match, categorized models are required for computational algorithms and inter-system and inter-component interfaces, and procedures for mapping one into the other. Models must be expressible in a computer-readable form in order to manage complexity with an interactive computer support system, permit the separation of structure from associated behavior, and support direct fabrication of the synthesized system.

*Programmatic Simulation*

Simulation, or dynamic design verification, is the process of calculating the behavior of a system within an environment specified by the designer. The objective of simulation is to verify that the system will perform correctly in an operational environment.

Ideally, simulation should be multilevel; i.e., consider larger structures and interact at a less detailed level with the capability of simultaneously simulating subcircuits more exactly. This concept

complements the hierarchical design implementation. In a hierarchical simulator, the basic elements are more complex than simple modules or gates. Models are formulated for entire IC's and include gate, function, and transistor models. Parts of a system are simulated in great detail while other parts are simulated abstractly. Models are written in high-level languages, with models for MSI or LSI blocks only slightly more complex than the model for a simple NAND gate. Thus a system of many thousands of devices or gates can be reduced to a few hundred hierarchical models, making it feasible to simulate entire VLSI systems.

*Testability*

Testing is the process of verifying that a system is operating properly. Because of the increased complexity of VLSI circuits, the difficulty of testing is substantially increased. To ensure that a circuit can be tested, design-for-testability techniques must be used throughout the design process.

Approaches to design-for-testability fall into two major categories: testable design styles and testability measure analysis. The use of a testable design style guarantees that generating tests for a circuit will not be impossible. Testability measure analysis computes the difficulty of controlling and observing each internal node from primary input or output pads. This information is used in the design process to locate potential circuit testing problems and provide feedback about the effect of circuit modifications on testability.

In developing a test sequence, knowing that a good test exists is not the same as knowing the test. Deriving a test is the task of the test sequence generation phase. Given a digital circuit and a set of possible faults, a series of input signals (vectors) is generated that will force any faulty circuit to behave differently from the fault-free circuit. The test sequences depend not only upon the intended function of the circuit but also upon the fault set assumed. Test-sequence generation must proceed concurrently with the hierarchical design process.

*Physical Design Aids*

Physical design aids include tools to partition, place, and interconnect circuit components and verification tools to ensure the synthesis has been performed properly. To provide an optimum system, physical design must be considered in parallel with functional design and testability.

*Partitioning*—Partitioning programs operate on both functional and physical entities. Partitioning techniques must function in both the initial design and detailed implementation phases. During top-down design, partitioning aids are needed for hierarchical decomposition. During bottom-up implementation, partitions are modified based on lower level implementations.

In addition to optimizing a circuit element assignment based on size and external pin connections, parameters such as circuit speed, power dissipation, and functional groupings must be considered. The partitioning aids must be capable of optimizing any of these quantities as a function of the others.

*Symbolic layout*—Provides a shorthand method for manually sketching a circuit layout using specified symbols to represent

DEF011956

## IEEE TRANSACTIONS ON COMPUTER-AIDED DESIGN OF INTEGRATED CIRCUITS AND SYSTEMS, VOL. CAD-1, NO. 1, JANUARY 1982

various types of transistors and interconnections. The initial layout can be performed on gridded paper or directly on an interactive graphics system. During layout, the designer is not concerned with the geometric design rules. Symbolic layouts are postprocessed using computer aids which expand and relocate all symbols and interconnects based on the geometric design rules for the specified technology to provide mask artwork files.

**Physical layout**—The physical layout phase of IC design involves positioning and interconnecting electrical components. In hierarchical design, the concept of a component is generalized. Components may range in complexity from primitive transistors and fundamental gates to microprocessors that can be combined to form a microcomputer.

Hierarchical layout is applicable to a wide range of physical design levels. At the highest design level, the shape of LSI components may be adjusted and combined to form a VLSI circuit. At the lower design levels, the same algorithms may be used to combine gates into registers or transistors into gates.

**Topological analysis**—Because of the high costs and long lead times involved in the fabrication of IC's, it is important to verify the correctness of a circuit design before manufacture. Verification tools must ensure correct physical mask layout, functional operation, and that electrical characteristics are within specified tolerances.

Topological analysis tools can be used to verify correctness of physical layout data by examining the artwork data and the circuit inputs and outputs. Design-rule checking codes perform geometrical, logical, and topological operations on artwork data and compare the results with design rules for the specified technology. Connectivity and electrical parameter data are used to reconstruct a detailed circuit including parasitic electrical components. This reconstructed circuit can be used in performing an accurate functional and timing analysis.

#### Circuit Design Documentation

After a circuit or system design has been completed, the design can be documented by collecting information from the data base generated during the design process. Design documentation includes information for fabricating the IC's and system as well as information for archiving the completed design to support later modifications. Computer aids should collect manufacturing and archival information and generate appropriate files, specifications, and reports.

#### Data Base

In general, the distinction between programs and data is that programs are active, data is passive (i.e., programs operate on data). The necessity for supporting the initial design, design changes, and providing software transportability dictates consistency in data handling procedures and mechanisms. Therefore, an efficient data base is vital for coordinating the various functions. As systems become more complex, it is imperative that an overall data base be established and maintained to ensure consistency in design and to eliminate duplication of information.



Fig. 8. Sandia hierarchical CAD system.

The data base must be designed in a flexible and modular fashion to provide upward compatibility with computer hardware and the evolving CAD software. Modularity is important where various portions of the data base may reside at more than one computer node. In addition to the actual data used by CAD programs, the data base should contain all necessary information to properly document elements being designed.

#### SANDIA CAD SYSTEM IMPLEMENTATION

A CAD System meeting the criteria outlined above is being implemented in phases at Sandia National Laboratories to provide design capability for LSI circuits initially, with evolutionary expansion and enhancement as required to support VLSI designs.

The design procedures consist of: (1) identifying critical areas in the design process based on user needs, (2) acquiring existing software when available and subsequently modifying it to meet system and user needs, (3) developing new aids with appropriate expansion capabilities to support hierarchical design, and (4) integration of all aids into the design system framework. A block diagram outlining the present system implementation is shown in Fig. 8. The solid blocks represent areas where design support is presently available, and the dashed blocks indicate work in progress. Brief descriptions of the hardware and software are given below.

#### Hardware

The software is supported on a dedicated DECSYSTEM 20 computer system containing 1 million words of main memory, 160 million words of disk files, and two 9-track 800/1600 bit/in., 75 in/s tape drives. Two Appleton 860 interactive graphics systems and a Versatec 36" electrostatic plotter are connected to the DECSYSTEM 20. A VAX 11/780 computer containing 4 megabytes of main memory, 323 megabytes of disk files, and 2 9-track 800/1600 bit/in. 125 in/s tape drives is interfaced in a network configuration to provide additional computing capability. Communication among the computer

DEF011957

UARY

## DANIEL AND GWYN: CAD SYSTEMS FOR IC DESIGN

and the Applicon systems is supported by DECnet. Both dial-up and direct-wired access to the system provide support for alphanumeric and graphics terminals.

## Design Software

A Universal HDL (UHDL) is being developed in essentially three stages consisting of: (1) language formation by phrase concatenation, (2) redundancy removal, and (3) consolidation and rewrite of the compound language. During the first step, the SDL [11] language (a PASCAL-like description) is used to describe system structure. Other languages are appended in phrase form to describe functional behavior. After gaining experience with the composite languages and after the deficiencies and required enhancements have been identified, a language for the initial UHDL will be written. Continuous refinement and enhancement of the UHDL will be required to meet design and documentation needs.

Translation from UHDL descriptions (initially SDL) to the required formats for simulation, layout, and verification programs is performed by the Design Executive. The Design Executive also manages the data flow between the Data Base files (outlined below) and each of the design aids.

Design synthesis aids currently available include MINI [12] and DDA [13] (Digital Design Aids). MINI, a Programmable Logic Array (PLA) minimization program uses a branch-and-bound algorithm to produce the optimal two-level realization of a set of Boolean equations. DDA provides synthesis of a sequential-state machine based on flow diagram, state assignment, and flip-flop type.

Logic-level design consists of defining, in complete detail, all components (gates, cells, modules, etc.) and interconnections required to implement a specified function. The SALOGS [14] (Sandia Logic Simulator) program performs true-value 4-state logic simulation (true, false, undefined, and high impedance) and 8-state timing simulation (four states plus transition to each of the four states) as well as states-applied and gate activity analysis and fault simulation. SALOGS is used for dynamic design verification, test sequence evaluation, and fault coverage calculations. Race and hazard analysis is available and the program is capable of using library or user-defined models.

A typical input/output for SALOGS is shown in Fig. 9 for a small logic circuit. The input consists of a connectivity description of logic gates or cells contained in the model library. The plotted output describes the logic signal changes as a function of time for each of the nodes indicated.

Although approximate timing simulation is accomplished in SALOGS through the use of extra states to represent logic values in transition, more exact timing simulation is possible with MOTIS-C [15] and SIMPIL [16] for MOS and I<sup>2</sup>L circuits, respectively. These programs use tables to describe active devices in a circuit instead of models with complex equations. Both programs provide more accurate analysis than logic simulators and run more efficiently than circuit simulation codes such as SPICE.

A more exact circuit analysis is obtained by using the SANCA (Sandia Circuit Analysis) program circuit simulation program based on SPICE. This program simulates MOS and bipolar



Fig. 9. Typical logic simulation input and output using SALOGS.

circuits, including analog and digital circuits, by numerically solving the network equations to calculate the desired voltages and currents. The cost of increased accuracy (over timing simulation) is a decrease in both execution speed and circuit size that can be analyzed. Model libraries [17] for circuit analysis are maintained to reflect varying levels of accuracy and different modeling philosophies. Circuit models based on device physics, empirical behavior, and hybrid approaches are all used in the circuit simulation environment. SANCA is an enhanced, quasi-interactive, topological analysis program containing model information for specific Sandia technologies and output plot routines.

Physical mask layout is performed using the SICLOPS [18], [19] (Sandia IC Layout Optimization System) and SLOOP [20] (Standard cell LayOut Optimization Program) programs to automatically place and interconnect generalized circuit elements. Two different forms of mask layout are used. A hierarchical mask layout system has been developed and used for specific designs. Hierarchical layout is applicable to a wide range of design levels. At one extreme, LSI components can be combined to form a VLSI circuit. At the other extreme, the same algorithms can be used to combine gates into registers based on a standard cell layout. This hierarchical approach relies on the use of SICLOPS to perform an automatic layout of an integrated circuit using rectangular-shaped blocks. The blocks must be rectangular and can be of arbitrary size and aspect ratio. The program automatically places the blocks and performs the interconnections. Each of the blocks can contain nested subblocks to any depth to provide a hierarchical layout. SICLOPS can also be used to layout a thick film hybrid circuit, as shown in Fig. 10.

The more conventional layout using standard cells placed in rows with interconnection between cell rows in routing channels is supported by SLOOP. In addition to designing modules used by SICLOPS, conventional standard cell IC layouts can be designed. The basic program can be used in an interactive mode to optimize the design, will perform a 100-percent completion of all interconnections by expanding the chip size as required to complete interconnections, contains hierarchical interfaces for use with the SICLOPS code, and supports multi-port gates or cells. A typical IC design using SLOOP is shown in Fig. 11.

DEF011958

10 IEEE TRANSACTIONS ON COMPUTER-AIDED DESIGN OF INTEGRATED CIRCUITS AND SYSTEMS, VOL. CAD-1, NO. 1, JANUARY 1982



Fig. 10. Thick-film hybrid circuit layout obtained using SICLOPS.



Fig. 11. Typical standard cell IC design using SLOOP.

DEF011959

JANUARY 1985 DANIEL AND GWYN: CAD SYSTEMS FOR IC DESIGN

11

The LOGMASC (LOGical MASK Checking) [21] program is a tool for design rule checking of IC masks. This program produces Boolean logic combinations of mask levels and is based on pattern recognition techniques. LOGMASC provides essentially all design rule checks which can be performed manually and provides pattern identification and extensive topological and geometrical information concerning the interrelationships of entities in the file. False errors are minimized by selectively applying design rule checks based on the circuit use of the particular patterns being checked. Many of the algorithms can be used to solve other mask analysis problems in addition to the design rule checks.

During the circuit mask design process, transistor current or voltage gains, resistance, and capacitance values are scaled and converted to area definitions based on the nominal circuit parameter values used for circuit analysis. The actual sizes of the circuit elements and devices are adjusted to fit layout constraints based on minimum spacing, relative element partitioning, and size requirements. The actual circuit defined by the mask layout may be quite different than the original circuit schematic. For example, the interconnection distances between transistors introduce resistances and capacitances into the circuit which were not included in the initial circuit simulation. Additional parasitic transistors and diodes can be unintentionally introduced into the circuit which can cause improper operation. The CMAT [22] (Circuit Mask Translator) code operates on circuit mask information, using pattern recognition to recognize and transcribe the mask areas into the circuit elements. CMAT employs the basic Boolean operations algorithms contained in LOGMASC and performs the required scaling operations to obtain circuit element values.

SCOAP [23] (Sandia Controllability Observability Analysis program) is used to evaluate the testability of a circuit after the basic circuit design has been completed. This analysis is performed prior to layout and is based on a simple analysis of the logic interconnectivity. The SCOAP program calculates the ease or difficulty of setting an internal node from a primary input to a zero or one and the difficulty of observing a logic value at any internal node from a primary output. The zero and one values for controllability may be different depending upon the exact circuitry and interconnection of the logic gates. For nodes having very high values for controllability or observability changes are usually required in the logic circuitry to reduce the controllability and observability numbers. This reduction is required, since the numbers are proportional to the testing difficulty. For nodes with high controllability/observability measures, additional input or output tie points or signal multiplexing may be required to set logic gates or observe node logic values to achieve circuit testability. At present, a structured design for testability, such as the IBM LSSD [24] approach, is not required. However, since the designer is responsible for designing a testable circuit, techniques equivalent to the LSSD approach may be used in the design based on the testability analysis information.

The testability analysis program is used for both combinational and sequential circuits. Combinational measures basically relate to the number of different line assignments or input assignments which must be made to set an internal node to a

#### SCOAP (SANDIA CONTROLLABILITY OBSERVABILITY ANALYSIS PROGRAM)



Fig. 12. Testability analysis using SCOAP.

given value. For sequential circuits, the measures relate to the number of clock cycles or time frames required to propagate a specified logic value from an input pad to a node or from a specific node to an output terminal.

An example of testability analysis is shown in Fig. 12. All input nodes are directly controllable as indicated for the four nodes with a "zero controllability" value of one. The most difficult node to control is usually an output node; for this example, output 2 has a zero controllability value of six. The observability is shown in the lower left of the figure. Again, the most observable nodes are the output nodes as indicated by the two nodes with an observability value of one. Ordinarily the most difficult nodes to observe are the input nodes and, therefore, the nodes A, B, C, and CLK should be the least observable. In this case, the CLK signal is input to a transmission gate between nodes AB and Q; a change of state at node AB must occur to observe the clock signal and, therefore, the CLK signal has the large value of 10 for observability.

#### Data Base

Because of the initial need for integrating loosely related CAD software and evolving design system specifications, a data-file base has been developed. The Sandia CAD data structure [25] is in the form of a "deciduous tree"; that is, one that can lose its leaves. This structure is a two-dimensional network with several restrictions. In one dimension the data structure forms a shallow tree one level deep. That is, any number of data types can be associated with a given node, but they may not be broken down further. In the other dimension, the structure is a network of nodes and subnodes to any depth. The leaves on the tree are the equivalent of small sequential files of data which can be retrieved by the user application program. This data file approach forces the designer to conform to a hierarchical structure while maintaining the freedom to store test files, documentation, etc., in the same file.

#### SUMMARY AND FUTURE PLANS

Although a basic computer-aided LSI design capability has been established and is used by design engineers, the system is continuously evolving as new capabilities and enhancements

DEF011960

## 12 IEEE TRANSACTIONS ON COMPUTER-AIDED DESIGN OF INTEGRATED CIRCUITS AND SYSTEMS, VOL. CAD-1, NO. 1, JANUARY 1982

are added. The modular programs and data structures, as well as the flexibility designed into the overall system framework, tend to minimize the cost for system modification as requirements change. In addition to continuous enhancement of existing programs, new aids for design synthesis, hierarchical simulation, symbolic layout, and test sequence generation will be developed. A continuing emphasis is placed on integrating the CAD software into a complete design system.

## REFERENCES

- [1] G. Kron, *Tensor Analysis of Network*. New York: Wiley, 1939.
- [2] —, "A set of principles to interconnect the solutions of physical systems," *J. Appl. Phys.*, vol. 24, pp. 965-980.
- [3] A. F. Malmberg, F. L. Cornwell, and F. N. Hofer, "NET-1 network analysis program," Los Alamos Rep. LA-3119, 1964.
- [4] R. W. Jensen and M. D. Lieberman, *The IBM Circuit Analysis Program*. Englewood Cliffs, NJ: Prentice-Hall, 1968.
- [5] A. Feller and M. D. Agostino, "Computer-aided mask artwork generation for IC arrays," in *Dig. 1968 IEEE Computer Group Conf.*, pp. 23-26.
- [6] A. Feller, "Automatic layout of low-cost quick-turnaround random-logic custom LSI devices," in *Proc. 13th Design Automation Conf.*, pp. 79-85, June 1976.
- [7] G. Penky, D. N. Deutsch, and D. G. Schweikert, "LTX-A system for the directed automatic design of LSI circuits," in *Proc. 13th Design Automation Conf.*, pp. 399-407, June 1976.
- [8] E. Cohen, Program reference for SPICE 2, Memo ERL-MS92, Electronics Research Laboratory, Univ. California at Berkeley, June 1976.
- [9] M. R. Barbacci *et al.*, The ISPS computer description language, Tech. Rep. Dept. of Computer Science, Carnegie-Mellon Univ., Pittsburgh, PA, Mar. 1978.
- [10] W. E. Cary *et al.*, An introduction to the DDL-P language, Tech. Rep. 163, Computer Systems Lab., Stanford Univ., Stanford, CA, Mar. 1979.
- [11] W. M. van Cleempot, A structural design language for computer-aided design of digital systems, Tech. Rep. 136, Digital Systems Lab., Stanford Univ., Stanford, CA, Apr. 1977.
- [12] J. Abraham, MINI-A logic minimization program, Univ. Illinois, Urbana, IL, 1977.
- [13] DDA-Digital design aids for state machine synthesis, Tektronix, private communication.
- [14] J. M. Acken and J. D. Stauffer, "Logic circuit simulation," *IEEE Circuits Syst. Mag.*, vol. 1, no. 2, pp. 3-12, June 1979.
- [15] S. P. Fan *et al.*, "MOTIS-C: A new circuit simulator for MOS LSI circuits," in *Proc. IEEE 1977 Int. Symp. on Circuits and Systems*, pp. 700-703, Apr. 1977.
- [16] G. R. Boyle, *Simulation of Integrated Injection Logic*, Memo UCB/ERL M78/13, Electron. Res. Lab., Univ. California at Berkeley, Mar. 1978.
- [17] D. R. Alexander, R. J. Antinone, and G. W. Brown, *SPICE 2 Modeling Handbook*, BDM/A-77-071-TR, May 1977.
- [18] B. T. Preas and W. M. van Cleempot, "Placement algorithms for arbitrarily shaped blocks," in *Proc. 16th Design Automation Conf.*, June 1979.
- [19] B. T. Preas and W. M. van Cleempot, "Routing algorithms for hierarchical IC layout," in *Proc. Int. Symp. Circuits and Systems*, July 1979.
- [20] SLOOP (Standard-Cell Layout Optimization Program), Sandia Lab., to be published.
- [21] B. W. Lindsay and B. T. Preas, "Design rule checking and analysis of IC mask designs," in *Proc. 13th Design Automation Conf.*, June 1976.
- [22] B. T. Preas *et al.*, "Automatic circuit analysis based on mask information," in *Proc. 13th Design Automation Conf.*, June 1976.
- [23] L. H. Goldstein, "Controllability/observability analysis of digital circuits," *IEEE Trans. Circuits Syst.*, vol. CAS-26, Sept. 1979.
- [24] E. B. Eichelberger and T. W. Williams, "A logic design structure for LSI testability," in *Proc. 14th Design Automation Conf.*, pp. 462-468, June 1977.
- [25] J. D. Stauffer, "SADIST (The Sandia Data Index Structure)," Sandia National Lab., Albuquerque, NM, SAND80-1999, Nov. 1980.



Marvin E. Daniel was born in Dexter, KS, on December 19, 1938. He received the B.S.E.E. degree from Kansas State University in 1961, the M.S.E.E. degree from University of New Mexico, Albuquerque, in 1963, and the Ph.D. degree in electrical engineering from Oklahoma State University, in 1966.

In 1961, he joined Sandia National Laboratories, Albuquerque, where he has worked in a variety of positions including: design of test equipment, application of minicomputer

automated test systems, development of mathematical models for CAD programs, modeling of radiation effects in semiconductor devices, analysis of weapon systems, economic studies of fusion and fossil fuel

energy systems, and for the past two-and-one-half years has been supervisor of the Computer-Aided Design Division in the IC Design and Fabrication organization. He is the author of numerous papers and

articles, particularly in the areas of programs and models for computer-aided design.

Marvin is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

He is a member of the IEEE, AIAA, and the American Physical Society.

## The CMU Design Automation System

## An Example of Automated Data Path Design

A. Parker, D. Thomas, D. Siewiorek, M. Barbacci, L. Haier, G. Leive, J. Kim

Carnegie-Mellon University  
Departments of Electrical Engineering and Computer Science  
Pittsburgh, Pennsylvania 15213

def #5

## Abstract

This paper illustrates the methodology of the CMU Design Automation System by presenting an automated design of the PDP-8/C data paths from a functional description. This automated design (using synthesis techniques) is compared both to DEC's implementation and the Intersil single chip implementation.

## 1. Introduction

As it is becoming possible to integrate larger numbers of logic components on a single chip, the need for more powerful design aids is becoming apparent. Indeed, these aids must be capable of supporting a designer from the system level of design down to the mask level. In this way the systems level designer can become more aware of the implications of higher-level design tradeoffs on implementation properties such as silicon area, power consumption, testability, and speed, and be able to make more timely use of new technologies. The ultimate goal of the Carnegie-Mellon University Design Automation (CMU-DA) System [12] is to provide a technology-relative, structured-design aid to help the hardware designer explore a larger number of possible design implementations. Inputs to the system are a behavioral description of the system to be designed, an objective function which specifies the user's optimization criteria, and a data base specifying the hardware components available to the design system.

The CMU-DA system differs from other design automation systems because the input design description is a functional specification. Such a specification provides a model that, while accurately characterizing the input-output behavior desired for the implementation, does not necessarily specify its internal structure. The system software collectively performs the synthesis function by transforming the input functional description into a structural description. The design process involves binding implementation decisions in a top-down manner as a design proceeds through the design system. More structural decisions are made at each level until a complete hardware specification is obtained, with the most influential design tradeoffs being performed first in order to cut down the design search space.

The purpose of this paper is to illustrate the methodology of the CMU-DA system. The results given here are worst case - many optimizations, which are straightforward have not been implemented yet; research is in progress on others. The design of the data path of a DEC PDP-8/E [5] from the ISP level through to a TTL and standard cell design will be discussed. Only the subset of the full DA system which is presently implemented has been used for this example. The



Figure 1: The CMU Design System

components are shown in Figure 1.

The PDP-8/E is first functionally described using the ISP language [1]. A data-memory allocator [7] is used to generate the structure of the data paths from the functional description. This allocation is in terms of abstract logic components. The next step in the design is to bind physical modules to the abstract design from a module database [9]. This step provides the system with the capability of designing relative to new technologies. This binding will be illustrated both in terms of TTL chips and the CMOS standard cells in the Sandia design system [10]. The standard cell output of the CMU-DA system is then translated for input to the Sandia design system. At this point, chip area can be calculated and detailed timing information can be gathered using SALOGS [3].

The paper will conclude by comparing these two alternative designs to commercial implementations.

This research is supported in part by NSF Grant MCS77-09730 and Army Research Office Grants DAAG29-76-G-0224 and DAAG29-78-G-0070.

## 2. The PDP-8/E Example

As the CMU-DA system has evolved, more complex design examples have been used to observe its performance. The use of the PDP-8/E is a major step in two ways: 1) It represents about a five fold increase in the circuit complexity over previously reported example designs [8], and 2) It is a commercially available system that has been implemented in various technologies by different manufacturers over several years. Thus it is possible to compare a non-trivial automated design to designs done by several designers with different logic components.

The PDP-8/E is one model in a family of computers having nearly identical ISP descriptions. (That is, they implement nearly the same instruction set, with different hardware structures). A portion of the ISP description used by the automated design system is shown in Figure 2.

The description begins by declaring the memory and processor state. A 13 bit link-accumulator (lac) register is defined but can alternately be accessed as the one bit link (L) and 12 bit accumulator (Ac). Next, instruction interpretation is defined using the declared memory and registers. After the instruction fetch and increment of the program counter in the instruction interpretation section, instruction execution (exec()) is called. Illustrated here are the six memory reference instructions. Not shown but implemented in the automated designs are the effective address calculation, input/output instructions, and the operate microinstructions. Note that the `lba=Mpl[pc]` instruction fetches the location pointed to by the `pc` and places it in the `lba` register. No mention need be made of transfer of the current `pc` to a memory address register, which is a part of the hardware structure.

The ISP description [1] is compiled into a representation which is machine readable by the data-memory allocator. The next sections will discuss the data-memory allocation (where an abstract data path is synthesized), a module binder that illustrates how the CMU-DA system can design relative to new technologies, and a translator to Sandia's SALOGS simulator [10].

## 3. The Allocation Process

The data-memory allocators perform a mapping function from the algorithmic (ISP) description to the data-path part of the hardware implementation, which is called a data-path graph. The data path consists of the data-storage elements, data operators, and data paths necessary to implement the operations specified in the algorithmic description. Due to the characteristics of the ISP language this mapping may be multi-valued in either direction, rather than a simple one-to-one translation.

The PDP-8/E design described here was produced by a data-memory allocator which uses the distributed-logic design style. This style of (or approach to) design encompasses design with small and medium scale integration components. As pointed out earlier, the allocator itself is technology relative and the mapping onto specific integrated circuit packages is performed by a separate module binder program. The process referred to as allocation throughout the remainder of this paper is a synthesis of logic using generic logic elements, data paths, operators, registers, and multiplexers, all of any bit width.

The procedure used by the allocator might be compared to a two-pass compilation. The first pass may be considered a syntax or feasibility check. The allocator inputs a parsed ISP description, constructs data structures analogous in function to symbol tables, and enforces constraints necessary to insure that the data-storage locations, logical mappings, and

```

pdp8 is
  BEGIN
    ! The basic PDP-8 instruction set (without extended arithmetic
    ! element) is implemented. No I/O devices are included in the
    ! description.

  ! MP State
    Mp:#01277771<0|11>,          ! Main memory
    Mm=0|11>,                      ! Memory buffer

  ! PC State
    lac=0|12>,                    ! Link ac register
    L<>=lac<0>,                  ! Link bit
    Ac=0|12>,                     ! Accumulator
    P=0|11>,                      ! Program counter
    Pm=0|11>,                     ! Last_pc=0|11>

  ! Instruction Interpretation
    .start :>
      BEGIN
        go = 1 NEXT
        rnm()
        END,
      run!Instruction.Interpretation is
        BEGIN
          IF go >>
            BEGIN
              ! In memory, lba=pc + pc NEXT
              Pm = P + 1 NEXT
              exec() NEXT
              IF interrupt=enable AND interrupt.request =>
                BEGIN
                  REGIN
                  Mpl0 = Pm NEXT
                  Pm = 1
                  END NEXT
                  RESTAT run
                END,
            END,
        END,
      ! Instruction Execution
      exec!Instruction.execution is
        BEGIN
          ! In memory
          IF lba=Mpl[pc] AND (lr LED 25) = half NEXT
          IF lr=L0 Z2 = Mm + Mpl(m1) NEXT
          DECODE lr =>
            BEGIN
              ! Read
              #1 = and(lac, Mm + Mpl(m1)) NEXT
              #2 = lac + lac + Mm + Mpl(m1) NEXT
              ! Write (TC)
              #3 = lac + Mm + 1 NEXT
              ! Increment and skip if zero
              #4 = Mm + Mm + 1 NEXT
              ! If the EOL 0 => Pm + Pm + 1
              ! Deposit and clear Mm
              #5 = lac + Mm + 1 NEXT
              ! Clear Mm
              Pm = 0
              END,
            END,
          #6 = Jmp to REGIN
          ! Jump to
          Pm = Pm NEXT
          Pm = Pm + 1
          END,
          #7 = Jmp to Pm + Mm
          ! Jump
          #8 = ret()          ! I/O execution
          #9 = oper()          ! Operate
          #10 = oper()         ! microin.
        END,
      END
    END of description
  
```

Figure 2: ISP Description of the PDP-8/E

Input/output interface characteristics specified in the description can be implemented in hardware. If no errors are encountered, it proceeds to allocate the basic data-storage structures called for in the description, and any additional data paths, storage, and operators necessary to implement variable-accessing schemes described by ISP. The second pass may be considered as the semantic phase, with the activity of code generation replaced by the allocation of data paths, operators, and additional storage as needed to implement the actions described in the ISP description. Parallelism analysis is performed at several levels to warn the user of error conditions and determine constraints relating to optimization of hardware. The allocation is then completed by the addition of multiplexing where required.

However, allocation differs from compilation in that in a compilation one is concerned with implementing the specified data operations on a fixed data part whose capabilities are known *a priori*. In allocation, the allocator must be able to recall and utilize the capabilities of a data part which is being dynamically created. The allocator thus works from the inside out, first creating the data storage and access structures, and then adding the necessary data paths and operators to perform the described data operations. Finally, the output of the allocator is a non-planar directed graph, rather than a linear list of compiled instructions.

The first version of the allocator is experimental, and it performs only minor optimizations on the allocated hardware. It has been designed to investigate the feasibility of performing the mapping from ISP to hardware, the types of data structures needed for allocation, and areas where optimizations are possible. In future, more sophisticated allocators.

The allocator has been designed as a possible skeletal structure for future allocators in order to standardize input/output formats and data structures.

#### 4. Performance of the Data-Memory Allocator

The allocator program was run using the ISP description of the PDP-8/E, and the resultant data paths are shown in Figure 3. A binding of modules was done by hand to compare the results of the allocator to the original DEC design (Figure 4) [5].

It is difficult to compare the automated PDP-8/E data-path design with the original DEC design for three reasons. First, the ISP description input to the allocator declares as registers some values the PDP-8/E uses but never stores explicitly in registers, such as the effective address. These show up as registers in the allocator's design. Second, the allocator designs distributed logic, and the DEC design was done in the central-accumulator design style. (That is, this allocator does not contain the design rules for large scale collapsing of the data paths into a central-accumulator style of design [13].) Third, the DEC design has assumed a boundary between the control and data-memory parts of the design, but the boundary is different from that imposed on the allocator by the ISP description. Thus some instructions, flags, and registers which must be declared explicitly in the ISP description are part of the control in the DEC design.

The main reason for the difference in design seen from the block diagram level of Figures 3 and 4 is that the design styles are different. The multiplexing is used in different ways. In the DEC version, the operators are shared, and are used to provide no-op paths from one register to another. In the CMU version, only registers are shared and use multiplexed inputs. The ISP language is partially the source of this disparity. In ISP, the user can repeatedly use register A as a destination from various sources. However, the expressions A+B and C+D do not imply nor discount a single adder. Other differences in the design include the use of multiplexers for shifting in the

DEC design, and use of true/complement 0/1 chips for creating complements. "ORing" of the MQ and AC registers in the DEC version is done within the multiplexing hardware. Constants are often created in one place and gated over already existent data paths to the registers. In the CMU version, these constants are multiplexed at the register inputs.

In spite of these differences, estimates of chip count indicate that the allocator produces a path graph which would require 392 more integrated circuit chips than the DEC designers used for the data paths and registers. These estimates were done by hand to gauge the performance of the allocator; an automatic binding is discussed in the next section. These estimates were made using the same 1970 technology chip set the DEC designers had to deal with. The 392 excess hardware can be found in multiplexers which connect the registers, the extra registers declared in the ISP description, and duplicated operators like increment and add. Much of this excess can be attributed to the lack of optimization capability in the allocator algorithm. Future, more sophisticated allocation algorithms, coupled with the capability for high level optimization [12] available in the complete CMU-DA system will be able to significantly improve the data part design.

Further analysis of this design is in progress and includes a manual implementation of the control part. Comparisons of the DEC and CMU data-path speeds will then be possible.

#### 5. Module Binding

The module binding phase of the CMU-DA system employs the Modular Data Base System (MDOS) and follows the data-memory allocation step. It has the task of translating the abstract links, memories, registers, and operations in a data-path graph into a design using physically realizable modules. A second pass of module binding will occur after control allocation.

At present the module binding portion of the design system is primarily a research tool that will be used to investigate automated module binding. A goal of this research is to model the module binding problem sufficiently to generalize this part of the CMU-DA system to handle a wide range of module types from LSI chips through Standard Cells. The implemented portions of MDOS were used to assist a designer in binding data-part modules in the CMU PDP-8/E data-path produced by the Data-Memory Allocator described in Section 4. The results of the data-part module binding are compared to the DEC PDP-8/E design in Section 7. A similar comparison will be made to the standard-cell binding after those results are presented in Section 8.

#### 6. Organization of MDOS

MDOS consists of four sections shown in Figure 5: an I/O section that is responsible for translating between the internal and external forms of the path graphs; a Module Data Base access mechanism; a command language interface; and the module binding mechanism.

The input/output section is the interface to other parts of the CMU-DA system. The path graph, generated by an allocator, is placed in internal form for processing. The output file has the same format as the input path graph (with module binding information appended) and can be reread by the input section for additional processing.

The Modular Data Base is a hierarchical data base that is distributed in various ASCII files. The highest level of the data base is the index, which is read automatically during system initialization. The index contains pointers to all defined design-style sets, each of which is a collection of module sets appropriate for a given design style. A design style set file contains pointers to the actual module set information (the "Data Book") and summary information (typical cost, speed,



Figure 3: Allocator Generated POP-8/E Data Paths



Figure 4: IXIC POP-8/E Data Paths



Figure 5: Organization of the Module Data Base System

load, and drive capabilities of modules in the set). Access to data base information during module binding occurs frequently and utilizes various levels of detail from basic type matching through specific delay and timing characteristics.

The Command Language Interpreter (CLI) is the experimenter/designer's interface to the module binding system. The CLI may be used only to select a file to be processed and direct the disposition of the resulting bound path-graph. The CLI also provides a number of tools to inspect the path-graph, modify the graph structure and bind designer selected modules to specific nodes of the graph.

The module binder applies transformations to both the path graph and module functions in order to match the desired behavior with the available building blocks. The graph transformations are localized decompositions or combinations of nodes that preserve the specific behavior. Module transformations are primarily combinations of nodes since modules cannot be physically decomposed. However, multifunction modules such as shift registers and ALUs may require partitioning of the non-conflicting functions of the same module onto separate nodes of the graph.

The most prevalent type of graph transform is localized to a single node or several connected nodes of a similar type. Registers are usually decomposed into nodes of smaller bit widths. Logical operators are usually modified by reduction to a canonical form, then synthesized with available module operations. Multiplexers and demultiplexers are frequently transformed from a single level to a multilevel form. Arithmetic operators (particularly the signed and complement arithmetic modes) require algorithmic decomposition.

A more complex type of transformation involves the combination of nodes of different types into single nodes capable of multiple functions. Shift operators and special purpose arithmetic operators (increment, decrement, and clear)

are generally combined with register functions in available module sets. These transformations often provide significant reductions in the graph complexity by elimination of constants and reduction of multiplexor size.

Operator node transformations primarily involve the application of axioms and identities to combine available modules into an aggregate that performs a desired function. Boolean identities and DeMorgan's Theorem will direct logical synthesis. Arithmetic mode transformations (for unsigned, signed-magnitude, two's complement, and one's complement) will be utilized to synthesize required modes from available modes.

In cases where single transformations on either the graph or the modules do not provide the desired match, an iterative approach will be utilized. The graph and the module transforms will be alternately applied until one or more matches are found, a cycle is detected in the transformations, no further gain is detected by applying transforms, or one of the system constraints (speed, cost, etc.) is violated by the resulting implementation.

A central goal of the CMJ-DA system is to produce designs that have been optimized toward the designer's objectives and fall within the external constraints. Module binding is the first operation in the design system that attaches actual costs to the implementation and its specific speed, delay, and power information available. Therefore, evaluation of the bound design must be performed to insure compliance with the constraints. Critical constraints (i.e. constraints which the design *must* meet) will be dynamically estimated by projecting the final value based on an extrapolation from the number of nodes remaining to be bound and the accumulated value for the nodes already bound; a true evaluation of the fully bound design will be made as a final pass to insure compliance with the constraints. The dynamic evaluation will be used to select between functionally identical module choices with different performance parameters.

## 7. PDP8 Baseline Example

A partial module binding of the PDP-8/E was done with the available pieces of MDBS, which contain limited transform capabilities.

The module binding section contains a set of primitive operations that can modify the path graph structure (but not its behavior). The operations allow register nodes to be split at bit boundaries, operator nodes to be joined into single nodes with wider bit widths, nodes to be inserted, and nodes to be deleted. These operations allow the path graph nodes to be transformed to conform with the structure of available modules. As the MDBS becomes more fully implemented, these primitive operations will be used to build larger scale path graph transforms that can be applied automatically.

The existing system aids the designer in producing correctly bound path graphs by the strict enforcement of rules concerning application of the structural modification primitives. These operations are restricted to minimize the possibility of modifying the behavior of the path graph. Some examples of these rules are:

- Nodes may not be deleted while connected to more than one link.
- Links may not be deleted while joining two nodes.
- Half links (i.e., signals to external sources) may not be deleted.
- Operator nodes may be joined only if they are of the same type.

A different but equally important kind of assistance is provided to allow the designer to display any aspect of the binding process. For example, the designer may display one module in the data base, all modules providing a specific function, or the entire data base.

The module choices were made by the designer using information from the path graph and a small TTL module data base from the distributed Design Style Sol. The purpose of binding the data part with the existing system is to contrast the module selection with a hand designed PDP-8/E. This example provides a worst-case from which to judge the performance of MOBS as more capabilities are added.

Figure 6 was generated by the MOBS. The registers (named variables), operators, and multiplexors are identified in the "Comp." (Component) column. The "Device" column lists the name of the selected package. "Mods." lists the number of modules required to implement the component function. The term "modula" refers to a separate functional unit in this context. There may be several modules contained in one package. "Pkgs." lists the number of packages required for each function. "Gates" is an estimate of the equivalent number of logic gates to implement the function. The percentage of the total gates required is listed in the "% Total Gates" column. The cost of each function implementation is computed as the basic cost for the number of packages required plus an overhead mounting cost of \$3.00 per package. The percentage of the total cost attributed to each function is listed in the "% Total Cost" column.

| Comp.           | Device  | Mods. | Pkgs. | Gates          | % Total Gates | Cost          | % Total Cost |
|-----------------|---------|-------|-------|----------------|---------------|---------------|--------------|
| ENOD            | SN74176 | 2     | 2     | 76             | 3.96          | 7.78          | 2.58         |
| LNC             | SN74154 | 3     | 3     | 185            | 9.50          | 11.87         | 3.87         |
| LAST.P          | SN74174 | 2     | 2     | 76             | 3.96          | 7.78          | 2.58         |
| PC              | SN74181 | 3     | 3     | 264            | 18.65         | 11.87         | 3.87         |
| MOR             | SN74174 | 2     | 2     | 76             | 3.96          | 7.78          | 2.58         |
| MAR             | SN74174 | 2     | 2     | 76             | 3.96          | 7.78          | 2.58         |
| TEMP-8          | SN74174 | 1     | 1     | 6              | 8.31          | 3.35          | 1.11         |
| TEMP            | SN74174 | 2     | 2     | 76             | 3.96          | 7.78          | 2.58         |
| EOL             | SN74185 | 3     | 3     | 93             | 4.87          | 11.37         | 3.77         |
| EOL             | SN74185 | 3     | 3     | 93             | 4.87          | 11.37         | 3.77         |
| INCR            | SN74183 | 3     | 3     | 106            | 5.66          | 16.77         | 3.57         |
| INCR            | SN74183 | 3     | 3     | 106            | 5.66          | 16.77         | 3.57         |
| AND             | SN74183 | 3     | 3     | 106            | 5.66          | 16.77         | 3.57         |
| OR              | SN74322 | 12    | 3     | 12             | 8.63          | 9.58          | 3.18         |
| OR              | SN74322 | 12    | 3     | 12             | 8.63          | 9.75          | 3.23         |
| 12HUX8          | SN74151 | 13    | 13    | 156            | 8.17          | 46.67         | 15.46        |
| 12HUX4          | SN74153 | 12    | 6     | 96             | 5.83          | 21.54         | 7.14         |
| 12HUX4          | SN74153 | 12    | 6     | 96             | 5.83          | 21.54         | 7.14         |
| 12HUX4          | SN74153 | 12    | 6     | 96             | 5.83          | 21.54         | 7.14         |
| 12HUX4          | SN74153 | 12    | 6     | 96             | 5.83          | 21.54         | 7.14         |
| 12HUX4          | SN74153 | 12    | 6     | 96             | 5.83          | 21.54         | 7.14         |
| 12HUX4          | SN74153 | 13    | 7     | 104            | 5.45          | 25.13         | 8.33         |
| <b>Total</b>    |         | 131   | 83    | 1989           | 100.00        | 391.54        | 100.00       |
| Component Class |         |       |       | <b>% Gates</b> |               | <b>% Cost</b> |              |
| Registers       |         |       |       | 38.40          |               | 19.17         |              |
| Operators       |         |       |       | 25.48          |               | 23.49         |              |
| Multiplexors    |         |       |       | 33.74          |               | 52.37         |              |

Figure 6: Module Utilization For PDP-8/E Data Part

The choice of registers differed from the hand module binding in a few locations. The hand bound PDP-8/E used SN74194s (four bit universal shift registers) exclusively while the MOBS chose SN74174s (six bit D registers) when there was no requirement for the added shift capability. The Program Counter (PC) register was selected as three Program Counter (PC) registers based on the INC flag associated with the path graph node. The Accumulator (AC) was first split into a one bit node and a twelve bit node, then the twelve bit part was allocated as three SN74194s. This is the same allocation that was done by hand. However, the

choice only satisfies the shift, ration flags (LSHFT and RSHFT). The increment requirement (INC) has effectively been partitioned out and must be bound separately.

The package count was 30% higher for the MOBS selection than for the DEC implementation (64 packages for DEC vs. 83 packages for MOBS). This agrees closely with the results obtained by selecting modules strictly by hand (refer to Section 4). The 30% difference is attributable to the different design styles used and the allocator's implementation of the design. Comparing the total cost of modules for the DEC implementation and the MOBS implementation (Figure 6), it is found that the costs also are 30% higher for the automated implementation, while the number of equivalent gates is 65% higher for the automated implementation. This indicates that MOBS chose modules with a higher level of integration than DEC did.

A comparison of the percentage of equivalent gates and the percentage of cost accumulated in three functional classes (registers, operators, and multiplexors) indicates surprisingly uniform comparisons. The percentage of both gates and cost is higher for registers in the MOBS implementation than in the DEC implementation. This trend is expected since the DEC PDP-8/E uses a central accumulator design style. Also, the slightly lower percentages for gates and costs in the operator class is reasonable for the DEC implementation. The most surprising comparison is the near identical percentage of gates devoted to data path routing (i.e. multiplexors). In the two designs implemented in different design styles, it would be expected that the central accumulator style would utilize more data path routing than the distributed style. This apparent anomaly is a clue to the area where the module binding can make local improvements in a path graph for distributed designs. By utilizing functions intrinsic to certain modules (such as the CLEAR on registers), constants and their associated data paths can be eliminated and improve the cost of implementing a design.

The TTL module binding using MOBS compares favorably with the DEC implementation and previous hand module bindings of the automated path graph. It is expected that much improvement in the package count (and the cost) is forthcoming as transforms and evaluation techniques are implemented in MOBS. However, TTL module binding is just one objective of a generalized design system. The following section discusses an approach to binding CMOS standard cells to a design with the objective of being able to automate and produce LSI designs.

#### 8. Standard Cell Generation

The Sandia standard cell library [11] can also be used as physical modules to implement the automated PDP-8/E data part design. Then, using the Sandia software package [4, 10], it is possible to produce a simulation, insert faults, and perform automated cell placement and IC mask generation for a CMOS LSI chip implementation.

The standard cell binder used for this experiment was a small, automatic package which accessed a local data base of Sandia cells. This package only performed the essential transformations on the graph-expansion of nodes to match the standard cells. However, this package also gives us a worst-case measure for module binding performance.

The translation of the design from one environment, the module binder output, to another, the simulator input, involves both the expansion of multi-bit paths produced by the module binder to the single bit connection format of the simulator input and also the explicit identification of fan-out points. In addition to this latter process, termed resolving, the translator must generate gate specific parameters, such as propagation delays, by compiling capacitances to obtain a realistic simulation using SALOGS. Delay parameters are inserted in the

simulation model by the use of delay gates with associated times.

The input to SALOGS is a description of the network, written in NDL [3]. NDL describes the interconnection of functional blocks. Input and control signals are generated through the SALOGS simulation language SALSIM [4]. In SALOGS, gate representation includes built-in simulator elements such as inverters, transmission gates, NAND, AND, OR, and NOR gates. In addition, any set of elements can be defined as a functional block and the block used as a new element.

The NDL can then be used to automatically generate an IOC mask and to determine chip area. The portion of the total data-path area taken up by the different modules is summarized in Figure 7.

| Component   | Area    | Total  | Number | Total         |        | Zst |
|-------------|---------|--------|--------|---------------|--------|-----|
|             |         |        |        | Total<br>Area | #Sales |     |
| PC          | 5124.3  | 6.3    | 178    | 9.4           | 15.8   |     |
| LAC         | 4377.1  | 5.0    | 117    | 6.5           | 8.9    |     |
| DDG         | 3819.0  | 5.2    | 117    | 8.5           | 8.9    |     |
| DR          | 432.8   | 8.6    | 18     | 1.6           | 1.6    |     |
| DNO         | 476.3   | 8.6    | 18     | 1.6           | 1.6    |     |
| 1711G5      | 14111.3 | 1.9    | 45     | 2.7           | 3.6    |     |
| 1711W       | 3544.6  | 4.8    | 100    | 8.0           | 9.3    |     |
| 221181000   | 4712.4  | 5.7    | 60     | 3.3           | 4.6    |     |
| 121014X     | 3981.6  | 5.3    | 56     | 3.1           | 4.3    |     |
| 121014Z     | 3981.6  | 5.3    | 56     | 3.1           | 4.3    |     |
| 121014A     | 3981.6  | 5.3    | 56     | 3.1           | 4.3    |     |
| 121014F     | 3981.6  | 5.3    | 56     | 3.1           | 4.3    |     |
| 121014J     | 9183.4  | 12.4   | 320    | 7.7           | 18.6   |     |
| CDU         | 1121.0  | 1.8    | 45     | 2.5           | 3.4    |     |
| TRN         | 2044.4  | 4.4    | 100    | 6.0           | 8.3    |     |
| LOST_P      | 2221.0  | 1.8    | 45     | 2.5           | 3.4    |     |
| HOT         | 1.03.8  | 1.8    | 45     | 2.5           | 3.4    |     |
| HOR         | 1323.0  | 1.8    | 45     | 2.5           | 3.4    |     |
| subtotal    | 57867.5 | 77.27  | 1308   | 72.52         | 100.87 |     |
| A-RND2      | 317.5   | 9.4    | 12     | 9.7           |        |     |
| 1+2+3+4+5+6 | 29101.0 | 3.3    | 74     | 4.1           |        |     |
| 291210000   | 140.0   | 3.6    | 58     | 2.0           |        |     |
| 1+2+3+4     | 140.0   | 0.2    | 3      | 0.2           |        |     |
| 1+2+3+4+5   | 140.4   | 4.2    | 6      | 0.3           |        |     |
| SUTCH       | 1223.2  | 1.8    | 45     | 2.5           |        |     |
| T           | 1371.0  | 1.8    | 45     | 2.5           |        |     |
| 2210.6      | 219.6   | 3.0    | 84     | 1.5           |        |     |
| 113.3       | 2460.9  | 3.3    | 84     | 4.7           |        |     |
| CCD         | 2460.9  | 3.3    | 84     | 4.7           |        |     |
| ING         | 1101.8  | 1.5    | 32     | 1.7           |        |     |
| 3+FLNG      | 1101.8  | 8.5    | 11     | 8.6           |        |     |
| TOTAL       | 74049.6 | 108.16 | 1817   | 100.87        |        |     |

Figure 7: Module Data from Translator

The upper portion of the Figure compares the size of the data-paths elements listed in Figure 3. The lower part of the table describes some modules that are more accurately defined as control than data-paths. As expected, the percent of sub-total gate count in the upper portion of the table closely resembles the results from the TTL breakdown shown in Figure 6.

In sum, the CMU PDP-8 design required 74,042 mil-sq, ignoring the area taken up by routing. The experience with Sandia's IC mask design system indicates that routing takes up about an additional 75% of the area occupied by the standard cells, yielding a chip area of 129,574 mil-sq. By way of comparison, Intersil's one-chip CMOS CPU implementation of the PDP-8 takes up 29,014 mil-sq [6]. It is estimated that 35% of Intersil's CPU chip is devoted to the functional elements equivalent to that generated by the CMU-DA system. Thus, there is a factor of 13 difference in the area required for the two designs.

A model can be devised to attribute this seemingly large difference to various parts of the design system. Since each part of the design: system builder on top of the previous stage, a multiplicative model is used. This model must take into account the non-optimality of the allocator, non-optimality of the module binder, differences in basic feature size, and the differences in routing techniques. The result of the allocator section indicates a design requiring 1.3 times the size of the DEC design. There is also a difference in the basic feature size of the Intersil and Sandia technologies. By way of comparison, a 12 bit register implemented with Sandia's standard cells occupies 4 times the area of equivalent register in Intersil's design [2]. The multiplicative model then becomes

$$13.8 = (1.3)(4)R,$$

where  $R$  is a factor indicating a difference in size between the CMU design and the Intersil design introduced by the module binder. In this case  $R = 2.5$ . Not included in the model are factors due to differences between hand packed and channel routing techniques, nor factors considering that large structures (e.g. wide multiplexers) can be more optimally designed by hand than by combination of simple standard cells.

In the worst case, assuming similar input structures and feature size, the CMU module binder would produce a design taking 2.5 times the area of the Intersil design. However, as discussed above, there are other factors which increase the CMU design size that were not accounted for in the model.

## 9. Summary and Conclusions

The paper has illustrated the methodology behind the CMU Design Automation System. In particular, the datapath of a non-trivial digital system (PDP-8/E) has been designed from an ISPL functional description. Two types of physical modules were bound to the datapath design.

The binding using TTL series modules indicated that the CMU design required 302 more modules than the DEC implementation. The binding using CMOS standard cells indicated that the CMU design is at most a factor of 2.5 off, and due to differences in routing techniques may be actually closer in area to the Intersil design.

As a whole the system has demonstrated the synthesis function in digital system design. The allocator research indicates automated logic synthesis with optimization is feasible and specific module-set information is not necessary in order to produce a reasonable design. The module binding section has demonstrated how the system can design relative to new technologies. Future work with the design system will deal with optimization techniques to be used in better directing the design algorithms for more complex designs.

## References

1. Barbacci, M., Barnes, G., Callicell, R., Siewiorek, D.: The Symbolic Manipulation of Computer Descriptions I: The ISPS Computer Description Language. Dept. of Computer Science, Carnegie-Mellon University, Pittsburgh, Pa., March, 1978.
2. Bell, G., C. Mudge, J.E. McNamara. Computer Engineering. Digital Press, 1978.
3. Case, G.R. and J.D. Stauffer. SALOGS-IV, Program to Perform Logic Simulation and Fault Diagnosis. Proceedings 15th Design Automation Conference. IEEE, 1978.

4. Case, G.R. and J.D. Stauffer. SALSIM - A Language for Control of Digital Logic Simulation. Proceedings of the 11th Annual Asilomar Conference on Circuits, Systems, and Computers, IEEE Circuits and Systems Soc., IEEE Control Systems Soc., Naval Postgraduate School, Univ. of Santa Clara, November, 1977, pp. 370-373.
5. DEC Staff. *POP-8/E Maintenance Manual*. Digital Equipment Corporation, 1972. DEC-8E-HR1B-D
6. Electronics Magazine Staff. CMOS, Moving Along. *Electronics* 48, 10 (May 1975).
7. Hafer, L. Data-Memory Allocation in the Distributed Logic Design Style. Master Th., Carnegie-Mellon University, December 1977.
8. Hafer, L.J. and A.C. Parker. Register-Transfer Level Automatic Digital Design: The Allocation Process. Proceedings of the 15th Design Automation Conference, IEEE, 1978.
9. Leive, G.W. The Binding of Modules to Abstract Digital Hardware Descriptions. PhD Thesis Proposal, Carnegie-Mellon University, 1977.
10. Press, B.T. and C.W. Gwyn. Lecture For Contemporary Computer Aids to Generate IC Mask Layouts. Proceedings of the 11th Annual Asilomar Conference on Circuits, Systems, and Computers, IEEE Circuits and Systems Soc., IEEE Control Systems Soc., Naval Postgraduate School, Univ. of Santa Clara, November, 1977, pp. 309-317.
11. Sandia Staff. *Standard Cell User's Guide*. Sandia Laboratories, 1978.
12. Snow, E.A., D.P. Siewiorek and D.E. Thomas. A Technology-Relative Computer-Aided Design System: Abstract Representations, Transformations and Design Tradeoffs. Proceedings of the 15th Design Automation Conference, IEEE, June, 1978.
13. Thomas, D.E. and D.P. Siewiorek. Measuring Designer Performance to Verify Design Automated Systems. Proceedings of the 14th Design Automation Conference, IEEE, 1977, pp. 411-418

# ARTIFICIAL INTELLIGENCE TERMINOLOGY

## a reference guide

Colin Beardon



DEF079212

First published in 1989

**ELLIS HORWOOD LIMITED**

Market Cross House, Cooper Street,  
Chichester, West Sussex, PO19 1EB, England

*The publisher's colophon is reproduced from James Gillison's drawing of the ancient  
Market Cross, Chichester.*

**Distributors:**

*Australia and New Zealand:*

JACARANDA WILEY LIMITED  
GPO Box 859, Brisbane, Queensland 4001, Australia

*Canada:*

JOHN WILEY & SONS CANADA LIMITED  
22 Worcester Road, Rexdale, Ontario, Canada

*Europe and Africa:*

JOHN WILEY & SONS LIMITED  
Baffins Lane, Chichester, West Sussex, England

*North and South America and the rest of the world:*

Halsted Press: a division of  
JOHN WILEY & SONS  
605 Third Avenue, New York, NY 10158, USA

*South-East Asia*

JOHN WILEY & SONS (SEA) PTE LIMITED  
37 Jalan Pemimpin # 05-04  
Block B, Union Industrial Building, Singapore 2057

*Indian Subcontinent*

WILEY EASTERN LIMITED  
4835/24 Ansari Road  
Daryaganj, New Delhi 110002, India

© 1989 Colin Beardon/Ellis Horwood Limited

**British Library Cataloguing in Publication Data**

Artificial intelligence terminology: a reference guide. —  
(Ellis Horwood series in artificial intelligence)

1. Artificial intelligence  
I. Beardon, Colin  
006.3

**Library of Congress CIP data available.**

ISBN 0-7458-0718-6 (Ellis Horwood Limited—Library Edn.)  
ISBN 0-7458-0763-1 (Ellis Horwood Limited—Student Edn.)  
ISBN 0-470-21601-8 (Halsted Press)

Printed in Great Britain by Hartnolls, Bodmin

**COPYRIGHT NOTICE**

All Rights Reserved. No part of this publication may be reproduced, stored in a retrieval system, or transmitted, in any form or by any means, electronic, mechanical, photocopying, recording or otherwise, without the permission of Ellis Horwood Limited, Market Cross House, Cooper Street, Chichester, West Sussex, England.

**AI**

[ \* ] AI is an abbreviation of '*Artificial Intelligence*'.

**AKO-link**

[knowledge representation] Generally, an AKO-link ('A-Kind-Of') is another name for an *inst-link* within a *semantic network*. In *KRL*, however, 'AKO-links' cover both *ISA-links* and inst-links.

See also: inheritance hierarchy, inst-link, ISA-link, semantic network.

**algorithm**

[software engineering] An algorithm is a specification, written in some notation, for a series of steps which, if carried out, will result in a particular task being performed. It expresses a general method for achieving a particular result, some examples of everyday algorithms being knitting patterns and recipes. Algorithms are used in computing to break down a given problem into a number of steps which can then be written as programming language statements.

See also: program, stepwise refinement, structured programming, top-down design.

**allophone**

[speech processing] Each *phoneme* can be realised in actual speech in a variety of ways depending, for example, on the sounds that precede or follow it. The set of alternative realisations of a phoneme is called an 'allophone'.

See also: phoneme, segmentation.

**alpha-beta pruning**

[game playing] Alpha-beta pruning is a technique applied to improve the efficiency of systems that play two-person *zero-sum* games. It is applicable where a *depth-first search* strategy with limited depth is employed using *evaluation functions*. It is based on the principle that, having fully evaluated one move, other moves are not worth exploring further once a counter-move has been discovered that makes them less attractive than some fully evaluated move. The name 'alpha-beta' acknowledges the fact that a move that is attractive to one player (alpha) is proportionately unattractive to their opponent (beta). The technique requires no extra knowledge to be applied yet can significantly improve efficiency, especially if the most likely move is explored first.

See also: game playing, game tree, minimax.

### antecedent

[linguistics] The antecedent of an anaphoric expression is the earlier linguistic expression which determines its *reference*.

See also: anaphor, anaphora.

[logic] In a conditional proposition, standardly expressed in the form

*if P then Q*

or in *propositional calculus*

$P \rightarrow Q$

the antecedent is the component proposition (*P*) immediately following the 'if', or, in logical notation, preceding the ' $\rightarrow$ '.

See also: consequent.

[problem solving] The term 'antecedent' can be used to refer to a small procedure that employs *forward chaining* techniques within a predominantly *backward chaining* system.

See also: antecedent rule, antecedent theorem.

### antecedent rule

[expert systems] An antecedent rule is a rule that performs *forward chaining* within a system that generally employs *backward chaining*. Antecedent rules are usually included for efficiency, to allow certain facts to be explicitly asserted, rather than being repeatedly inferred by the application of rules. Antecedent rules are employed in *MYCIN*.

See also: assert, backward chaining, forward chaining, inference.

### antecedent theorem

[PLANNER] An antecedent theorem in *PLANNER* behaves like an *if-added demon*. It allows the programmer to specify actions that are to be performed whenever a fact of a particular kind is *asserted*. It can be used to explicitly record certain properties of objects by asserting appropriate facts, thus avoiding excessive use of inferencing where a property is often referred to. For example, an antecedent theorem might assert

**animate(X)**

whenever a fact of the form

**male(X)**

was asserted.

See also: assert, if-added demon, inheritance hierarchy, PLANNER.

## connectivity

[connection science] Connectivity refers to the pattern of *weighted* links between units in a connectionist network. There may be partial connectivity, where some of the units are connected to one another, or there may be complete connectivity, where every unit is connected to every other unit.

## CONNIVER

[programming languages & problem solving] CONNIVER is a *problem solving* language that was designed to overcome the automatic *backtracking* in *PLANNER* by enabling the programmer to direct the flow of control in the *program*.

See also: backtracking, PLANNER.

Ref: Sussman, G.J. & McDermott, D. (1972) *Why Conniving is better than Planning*.

A.I.Memo 255A, MIT, Camb, Mass

## connotation

[philosophy] J.S. Mill distinguished between the connotation and the *denotation* of a word. In using a word, such as chair, one implies that the things to which it applies have certain properties, such as 'being a piece of furniture' and 'designed for sitting on'. Those properties make up the connotation of the word.

See also: denotation, intension, sense.

## CONS

[LISP] CONS is a *LISP function* that takes an *S-expression* and a *list* and creates a new list consisting of the S-expression as its *head*, followed by the old list as its *tail*, e.g.

*cons('a '(b c))*

will produce the list

*(a b c)*

See also: CAR, CDR, dotted pair, LISP, list, quote.

## consequent

[logic] In a conditional proposition, standardly expressed in the form

*if P then Q*

or in *propositional calculus*

*P → Q*

the consequent is the component proposition (*Q*) immediately following 'then', or, in logical notation, following ' $\rightarrow$ '.

See also: antecedent.

### expectation based parser

[computational linguistics] At various stages when processing text, a top-down *parser* will be faced with a number of tests that can be applied. An expectation-based parser uses what it has already parsed to restrict its choice at this point by only carrying out tests that it has predicted. The entry for each word in the *lexicon* will contain the categories to which it belongs and some expectations about what may appear next and actions to be performed if the expectations are met. The parser is initialised to a *set* of expectations at the start of the sentence before processing commences.

For example, the word 'the' might expect a noun to follow and, if it does, it can record that a noun-phrase has been found. The process of setting up expectations based on the lexical entries for words, seeing if these expectations are satisfied, and carrying out their actions, is repeated until the end of the sentence is predicted and found, or the input does not match any expectation.

See also: categorial grammar, English Language Interpreter, word-expert parser.

### EXPEL

[conceptual dependency] EXPEL is a *primitive act* within *conceptual dependency* representation that represents the expulsion of an object from the body of an animal.

See also: conceptual dependency, primitive act.

### EXPERT

[knowledge representation] EXPERT is a simple *knowledge representation* language designed for general use in representing expert knowledge. It is best suited to diagnosis or classification problems, which is one of the reasons it is most widely used in medical applications. EXPERT is implemented in FORTRAN which makes it portable and efficient.

See also: KRL.

Ref: Weiss, S. M., Kulikowski, C. A. (1979) EXPERT: a system for developing consultation models. In: *Proceedings of the sixth IJCAI*, Tokyo

### expert system

[\*] An expert system is a computer *program* which attempts to embody the knowledge and decision-making facilities of a human expert in order to carry out a task generally regarded as requiring some degree of human expertise. Expert systems usually operate within restricted domains, some well known examples being medical diagnosis and mineral exploration. Their reasoning is essentially *heuristic*, in that an *algorithmic* approach which is guaranteed to produce an *optimal* solution to a problem, is not feasible. An expert system will generally

consist of a *rule base*, an *inference* engine and a user interface (which will generally provide an explanation facility).

**See also:** CADUCEUS, CENTAUR, DENDRAL, INTERNIST, knowledge-based system, MACSYMA, MYCIN, PROSPECTOR, rule base, shell, TAXMAN, XCON.

### explanation-based learning

[machine learning] Explanation-based learning (EBL) involves the learning of a concept from a single example. The *domain* theory held by the system is used to explain why the example is an instance of the concept under study. In explanation-based generalisation, a subset of EBL, this explanation is generalised so that the resulting rule may be applied to similar, though not necessarily identical, situations.

**See also:** concept learning, learning by induction, similarity-based learning.

### exponential

[mathematics] The term 'exponential' in mathematics indicates that a term is raised to a power (normally greater than 1). For example, '2<sup>3</sup>' is expressed exponentially, whereas '8' is not.

[software engineering] The term exponential is used to describe algorithmic *complexity*. An *algorithm* whose complexity for **n** inputs is measured in terms of  $C^n$ , for some constant **C**, is called an exponential algorithm. Most exponential algorithms are not feasible for any but the smallest input data problems.

**See also:** algorithm, combinatorial explosion, complexity, order of complexity, polynomial.

### extended Horn clause

[logic] For the purposes of practical *logic programming*, *Horn clauses* are over-restrictive and some extensions to Horn clause notation have been adopted by logic programming languages such as *PROLOG*. For example, a Horn clause, by definition, allows at most one unnegated *literal*. When a Horn clause is converted to PROLOG notation this means that there can be no negated terms in the *body* of the PROLOG *clause*. To get around this limitation a special form of *negation* (called *negation-as-failure*) is introduced that can be applied to terms in the body of a clause. This is one way in which PROLOG notation is an extension of Horn clause notation, others include the use of operators such as *cut*.

**See also:** clause, cut, Horn clause, negation-as-failure.

## inductive logic

[logic] In an inductive logic the conclusion follows from the premises only with a degree of probability and an additional premise may change the probability of the conclusion. The *conjunction* of the premises and the *negation* of the conclusion is not a contradiction.

Thus typically one may infer from a finite number of statements such as "*raven*<sub>1</sub> is black", "*raven*<sub>2</sub> is black" ... "*raven*<sub>*n*</sub> is black", the conclusion "all ravens are black". Clearly the conclusion only follows with a certain probability and the addition of the new premise "*raven*<sub>*n*+1</sub> is not black" would invalidate the *inference*. Inductive logic is contrasted with *deductive logic*.

**See also:** BACON, concept learning, deductive logic, learning by induction, non-monotonic reasoning.

## inference

[logic] An inference is the drawing of a conclusion, or alternatively is just the conclusion drawn. A logical inference can be expressed as a relationship among a set of sentences or propositions.

**See also:** argument, deductive logic, inductive logic.

## inference engine

[expert systems] An inference engine is that part of an expert system that interprets rules and facts in order to make *inferences*. Depending upon the system, it may be driven by a specific question (*backward chaining*) or attempt to make inferences from a set of *data* (*forward chaining*). Often a combination of both methods is employed.

**See also:** chaining, expert system, inference, rule base.

## infinite loop

[software engineering] An infinite loop is a series of programming language statements which will repeat indefinitely, usually due to an error in the *program* code. The failure to alter a control *variable* within an iterative statement is a typical cause of infinite loops. For example, if *x* = 1, then the loop,

```
while x <= 10 do write ('hello')
```

will repeat indefinitely.

**See also:** tractable.

### kludge

[ \* ] A kludge is a part of a mechanism whose behaviour cannot be simply explained by reference to the principles adopted by the rest of the mechanism, or by universal principles. Kludges can be best explained by a number of *domain-specific* rules. Insofar as the mechanism operates within a *paradigm*, the term 'kludge' can refer to aspects of its behaviour that are better explained by theories external to the paradigm. For example, aspects of human behaviour may be better explained in terms of human evolution, rather than as integral aspects of a *symbolic information processing* system.

### knowledge acquisition

[expert systems] Knowledge acquisition is the activity of attempting to make explicit the relevant knowledge of a human expert. Often the objective is to encode the expertise of the human expert in terms of the formal notation of an expert system (e.g. rules, *metarules* and facts). This can be broken down into three stages: eliciting knowledge, encoding it in some *canonical representation*, and validating it by making sample *inferences* which can be checked by domain experts and give rise to amendments.

See also: expert system, knowledge elicitation, knowledge engineer, TEIRESIAS, validation.

### knowledge based system

[ \* ] A knowledge based system (KBS) can be contrasted to a *database* or *information retrieval* system. In the latter cases information is retrieved from a store in response to precise requests and only the information described is presented. In KBS a more general goal can be stated and the system may make any relevant *inferences* in order to provide an appropriate answer. The result may not carry absolute certainty, but should represent an intelligent response to a problem given the knowledge available to the system.

The term 'Knowledge based systems' is sometimes used synonymously with 'expert systems', though it is usually taken to be a more general term incorporating, for instance, some *natural language processing* systems.

See also: database system, expert system, information retrieval.

### knowledge elicitation

[expert systems] Knowledge elicitation is the task of trying to make explicit the knowledge behind the performance of experts in their particular *domain*. One method is to ask the experts to explicitly state the rules they work by, but this does not always work well as their expertise is essentially performative, rather than *declarative*. An alternative approach is for the expert to give examples of their reasoning and for rules to be derived from these. In other cases, rules may be found ready formalised in text books or similar literature.

See also: expert system, knowledge acquisition, knowledge engineer.

### production system

[expert system] A production system is an *inference* system that consists of three parts: the working memory, which represents the *current state* of the inference (also known as the 'context' or 'short-term memory buffer'); the production memory, which represents the inference rules; and the rule *interpreter*, which applies the rules to the working memory. At each cycle all of the rules in the production memory are examined to see if their conditions are satisfied in the working memory and a list of rules that can be fired is produced. A *conflict resolution* strategy is then employed to decide which rule to fire. The action part of the chosen rule is executed and the working memory is updated as a result. This process continues until either the working memory contains the *goal*, or no more rules can be fired.

See also: DENDRAL, MYCIN, OPS5, production rule, PROSPECTOR.

### program

[computer systems] A computer program consists of a series of definitions and/or instructions conforming to the *syntax* of a given programming language which, when executed on, or interpreted by, a computer will perform a certain task. A program is often defined as being a marriage between *data structures* and *algorithms*. Because programs will be executed on some machine, they are essentially *procedural*, yet insofar as they describe the problem in terms of its own *domain*, they may also aspire to being *declarative* or functional.

See also: algorithm, data structure, declarative, procedural.

### program synthesis

[problem solving & programming] Program synthesis (also known as *automatic programming*) involves the generation of computer program code given some description of the problem in another form. This description might be in the form of examples of behaviour, a statement in a *formal language* (such as *logic*), a description in natural language, or result from an interactive dialogue.

## PROGRAMMAR

[computational linguistics & programming languages] PROGRAMMAR is a *natural language parsing* system developed by T.Winograd for the *SHRDLU* project. Though formally similar to an *ATN*, PROGRAMMAR is based upon ideas from *systemic grammar*. The language to be parsed is defined *procedurally*, enabling special purpose mechanisms to be introduced if required. It attempts to be as deterministic as possible, though facilities do exist for *backtracking* and trying alternative paths.

See also: augmented transition network, deterministic parsing, SHRDLU, systemic grammar.

## ROSIE

[expert systems] ROSIE is an artificial, English-like language for expressing facts and *inference* rules within expert systems. Though some of its constructs are quite formal, it can be read and interpreted *declaratively* once certain conventions are learned.

## rote learning

[learning] Rote learning refers to knowledge accumulation involving no transformations or processing of the information received. Forms of rote learning include learning by being programmed and learning by memorisation.

See also: learning from instruction.

## rule base

[expert systems] Just as a *database* is essentially a collection of data, so a rule-base is a collection of rules. Typically the term is used to refer to the set of rules in an *expert system*.

See also: production memory.

## rule-based system

[expert systems] A rule-based system is any system that represents knowledge as a set of *rules* that can be interpreted in a uniform way by applying them to known *facts* to infer new facts. The objective of a rule-based system is to encode practical human knowledge in such a way that it can mimic the *problem-solving* abilities of a human expert.

See also: expert system, inference.

## runtime error

[programming] A runtime error is one which occurs after *compilation*, during the execution of the translated source program. This sort of error is often due to a *semantic* error or a memory violation.

See also: bug, compilation error, debugging, semantic.

## runtime stack

[programming languages] A runtime stack is a mechanism for giving a *procedural* interpretation of the way that one process can call another during the execution of a *program*. Any language that allows the recursive calling of processes (e.g. *procedures* in Pascal, *clauses* in *PROLOG*, *functions* in *LISP*) will need to keep track of suspended processes and their return points, and a *stack* is an obvious choice for this.

See also: clause, function, nondeterminism, procedure, recursion, stack.

**DEF079449**

## word recognition

[cognitive psychology] The study of word recognition is the study of the mental processes involved in identifying the meanings of words. Word recognition involves encoding the initial percept of the word, locating the appropriate entry in the *mental lexicon*, and selecting the appropriate meaning for a given context. Several alternative models of word recognition have been proposed.

See also: lexical access, logogen model, mental lexicon.

## working memory

[cognitive psychology] Working memory refers to that part of human memory that is sometimes called *short term memory*. Working memory is a transient store of information that can be maintained only through rehearsal. Use of the term 'working memory' emphasises the fact that the information is being held for use by mental procedures. Information can be retrieved from *long term memory* and held active in working memory as various computations are completed.

See also: long term memory, short term memory.

## workstation

[computer systems] Workstations are usually stand-alone, single-user computers, but their power is such that they can normally support many users. Workstations sometimes lend themselves to specific applications, such as graphics and large scale numerical computation.

## WPE

[programming languages] WPE is an abbreviation of 'Warren Prolog Engine' which is the same thing as the *Warren Abstract Machine*.

Teresa M. Corbin (SBN 132360)  
Thomas Mavrakakis (SBN 177927)  
HOWREY SIMON ARNOLD & WHITE, LLP  
301 Ravenswood Avenue  
Menlo Park, California 94025  
Telephone: (650) 463-8100  
Facsimile: (650) 463-8400

Attorneys for Plaintiff SYNOPSYS, INC.  
and for Defendants AEROFLEX INCORPORATED,  
AMI SEMICONDUCTOR, INC., MATROX  
ELECTRONIC SYSTEMS, LTD., MATROX  
GRAPHICS INC., MATROX INTERNATIONAL  
CORP. and MATROX TECH, INC.

UNITED STATES DISTRICT COURT  
NORTHERN DISTRICT OF CALIFORNIA  
SAN FRANCISCO DIVISION

RICOH COMPANY, LTD., ) Case No. C03-04669 MJJ (EMC)  
Plaintiff, ) Case No. C03-2289 MJJ (EMC)  
vs. )  
AEROFLEX INCORPORATED, et al., )  
Defendants. )  
)  

---

SYNOPSYS, INC., ) Date: October 29, 2004  
Plaintiff, ) Time: 9:30 AM  
vs. ) Courtroom: 11  
RICOH COMPANY, LTD., a Japanese ) Judge: Martin J. Jenkins  
corporation )  
Defendant. )

## MANUAL FILING NOTIFICATION

Regarding: Exhibit 15 to Responsive Claim Construction Brief

This filing is in paper or physical form only, and is being maintained in the case file in the Clerk's office. If you are a participant in this case, this filing will be served in hard-copy shortly. For information on retrieving this filing directly from the court, please see the court's main web site at <http://www.cand.uscourts.gov> under Frequently Asked Questions (FAQ).

This filing was not efiled for the following reason(s):

[X] Voluminous Document (PDF file size larger than the efilings system allows)

[ ] Unable to Scan Documents

Physical Object (description): \_\_\_\_\_

Non-Graphic/Text Computer File (audio, video, etc.) on CD or other media

[ ] Item Under Seal

[ ] Conformance with the Judicial Conference Privacy Policy (General Order 53).

Other (description): \_\_\_\_\_

MICROSOFT PRESS®

# COMPUTER DICTIONARY



THE COMPREHENSIVE  
STANDARD FOR  
BUSINESS, SCHOOL,  
LIBRARY, AND HOME

**Microsoft**  
PRESS

DEF083323

PUBLISHED BY

Microsoft Press  
A Division of Microsoft Corporation  
One Microsoft Way  
Redmond, Washington 98052-6399

Copyright © 1991 by Microsoft Press, a division of Microsoft Corporation.

All rights reserved. No part of the contents of this book may  
be reproduced or transmitted in any form or by any means without  
the written permission of the publisher.

Library of Congress Cataloging-in-Publication Data  
Microsoft Press computer dictionary : the comprehensive standard for  
business, school, library, and home.

p. cm.

ISBN 1-55615-231-0

1. Computers--Dictionaries. 2. Microcomputers--Dictionaries.

I. Microsoft Press.

QA76.15.M54 1991

004.16'03--dc20

91-9904

CIP

Printed and bound in the United States of America.

2 3 4 5 6 7 8 9 MLML 6 5 4 3 2 1

Distributed to the book trade in Canada by Macmillan of Canada, a division  
of Canada Publishing Corporation.

Distributed to the book trade outside the United States and Canada by  
Penguin Books Ltd.

Penguin Books Ltd., Harmondsworth, Middlesex, England

Penguin Books Australia Ltd., Ringwood, Victoria, Australia

Penguin Books N.Z. Ltd., 182-190 Wairau Road, Auckland 10, New Zealand

British Cataloging-in-Publication Data available.

**Acquisitions Editor:** Marjorie Schlaikjer

**Project Editor:** Mary Ann Jones

**Technical Editors:** David Rygmyr, Jeff Hinsch, Mary DeJong, Dail Magee, Jr.

**Manuscript Editor:** Pamela Beason

**Copy Editor:** Alice Copp Smith

DEF083324

expansion

exponent

lated on 8086/8088 or 80286 machines as well, but the performance is poor. *Compare* conventional memory, extended memory.

**expansion** A means of increasing the capabilities of a microcomputer by adding hardware designed to perform a task that is not built into the basic system. *Expansion* is generally used in reference to the addition of printed circuit boards (expansion boards) that plug into openings (expansion slots) inside the body of the computer. In IBM personal computers and others designed as open-ended systems, these slots enable expansion boards and associated devices to connect with and transfer information on the computer's main data highway, the bus. Computers with expansion slots can be equipped with as many additional pieces of hardware as there are slots available. *See also* expansion slot, open architecture.

**expansion board** A circuit board holding chips and other electronic components connected by conductive paths that is plugged into a computer's bus (main data-transfer path) to add functions or resources to the computer. Typical expansion boards add memory, disk-drive controllers, video support, parallel and serial ports, and internal modems. The simple terms *board* and *card* are used interchangeably by most people to refer to all expansion boards. *See also* expansion slot.

**expansion bus** *See* AT bus.

**expansion slot** A socket inside a computer console, designed to hold expansion boards and connect them to the system bus (data pathway). Most personal computers have from three to eight expansion slots, with the notable exceptions of the Apple Macintosh and Macintosh Plus, which have none, and the Macintosh SE, which has one. Expansion slots provide a means of adding new or enhanced features or more memory to the system. *See also* expansion board.

**expert system** A type of application program that makes decisions or solves problems in a particular field, such as finance or medicine, by using knowledge and analytical rules defined by experts in the field. Human experts solve problems by using a combination of factual knowledge and reasoning ability. In an expert system, these two

essentials are contained in two separate but related components, a knowledge base and an inference engine. The knowledge base provides specific facts and rules about the subject, and the inference engine provides the reasoning ability that enables the expert system to form conclusions. Expert systems also provide additional tools in the form of user interfaces and explanation facilities. User interfaces, as with any application, enable people to form queries, provide information, and otherwise interact with the system. Explanation facilities, an intriguing part of expert systems, enable the systems to explain or justify their conclusions, and they also enable developers to check on the operation of the systems themselves. Expert systems originated in the 1960s; fields in which they are used include chemistry, geology, medicine, banking and investments, and insurance. *See also* artificial intelligence, intelligent database.

**exploded view** A type of display that shows a structure with its parts separated but drawn in relation to one another. See the illustration. A charting program, for example, could create an exploded pie chart by separating one segment from the rest of the pie. Similarly, an engineering or architectural drafting program could display a structure with its parts exploded outward so that the designer can view the pieces separately but as parts of the whole.

**exponent** In mathematics, a number that shows how many times another number is used as a factor in a calculation. Although exponents are commonly thought of as representing higher powers of a number, only positive exponents, as in  $2^3$ , indicate multiplication (2 times 2 times 2). Negative exponents, as in  $2^{-3}$ , indicate division (1 divided by  $2^3$ ), and fractional exponents, as in  $8^{1/3}$ , indicate the root of the number (here the cube root of 8).

In the floating-point, or exponential, notation commonly used with computers, the exponent is a number that indicates the power of 10 to be multiplied by the number in the fixed-point portion of the notation. Essentially, the exponent in a floating-point number shows the number of places the decimal point is moved to the right (positive exponent) or to the left (negative exponent) when the number